I am attempting to get my arms around some basic prolog but struggling a bit in the process. In specific – I am trying to get through a list of items and copy it, item by item into a new list. I can get it to reverse, but I am finding it trickier doing it without reversing.
Ive been trying the following –
copy(L,R) :- accCp(L,R).
accCp([],R).
accCp([H|T],R) :- accCp(T,H).
When i run a trace on this – i can see the individual items being copied across, but they get ‘lost’, and dont form a growing list (at R, as i was hoping). How could i achivie this?
Many thanks
Your base case needs to set the copy list to empty when the original list is empty. Then, the recursive case needs to take
Hfrom listLand add it to the head of listR:When you call
copy, it works its way down to the base case, where it setsRto an empty list. Then, as it works back up, it keeps appending the headHof known list[H|T1]to the beginning of variable list[H|T2]. It does that until the original case is reached, at which pointRcontains a full copy ofL.