Вы можете начать с того, что у вас уже есть:
encode(['a','b','b','c','c','c','d','d'], X) :-
X = [ (a, 1), (b, 2), (c, 3), (d, 2) ] .
, что также означает, что
encode(['b','b','c','c','c','d','d'], X2) :-
X2 = [ (b, 2), (c, 3), (d, 2) ] .
и, таким образом,
encode(['a','b','b','c','c','c','d','d'], X) :-
encode(['b','b','c','c','c','d','d'], X2)
X = [ (a, 1) | X2 ] .
, что это то же самое, что и
encode( L, X) :-
L = ['a','b','b','c','c','c','d','d'],
L = [ H | T ],
encode( T, X2),
X = [ (a, 1) | X2 ] .
, что совпадает с
encode( L, X) :-
L = ['a','b','b','c','c','c','d','d'],
L = [ H | T ],
encode( T, X2),
add_encoded( H, X2, X).
add_encoded( 'a', [ (b, 2), (c, 3), (d, 2) ], X2 ) :-
X2 = [ (a, 1) | [ (b, 2), (c, 3), (d, 2) ] ] .
Вы видите? Вы видите, как код записывает себя , когда мы обобщаем наши конкретные случаи, заменяя конкретные термины логическими переменными? Вы можете продолжить это еще?