Я не могу воспроизвести вашу проблему. С SWI-Prolog и лимитом стека в 1 ГБ я могу составить список из 10 000 000 элементов (это 1e7) и успешно применить к нему свой предикат.
?- N = 10 000 000, length(L, N), maplist(=(0), L), incNth(N-1, L, R).
N = 10000000,
L = [0, 0, 0, 0, 0, 0, 0, 0, 0|...],
R = [0, 0, 0, 0, 0, 0, 0, 0, 0|...] ;
false.
Этот список в 2 * 10 раз длиннее вашего.
Если я пытаюсь составить еще более длинный список, это когда у меня заканчивается свободное место в стеке. Уже это бросает:
?- N = 50 000 000, length(L, N).
ERROR: Stack limit (1.0Gb) exceeded
ERROR: Stack sizes: local: 1Kb, global: 4Kb, trail: 2Kb
ERROR: Stack depth: 11, last-call: 18%, Choice points: 3
ERROR: In:
ERROR: [11] system:'$length'(_1226, 50000000)
ERROR: [9] system:'<meta-call>'(<compound (:)/2>)
ERROR: [8] '$tabling':'$wfs_call'(<compound (:)/2>, <compound (:)/2>)
ERROR: [7] '$toplevel':toplevel_call(<compound (:)/2>, <compound (:)/2>)
ERROR: [5] '$toplevel':'$execute_goal2'(<compound (:)/2>, [length:3])
ERROR:
ERROR: Use the --stack_limit=size[KMG] command line option or
ERROR: ?- set_prolog_flag(stack_limit, 2_147_483_648). to double the limit.
Пожалуйста, покажите, как вы запускаете программу и какую ошибку вы видите. Также скажите нам, какую реализацию Prolog вы используете.