3 回答
TA貢獻(xiàn)1779條經(jīng)驗(yàn) 獲得超6個(gè)贊
這是一個(gè)簡(jiǎn)單的解決方案nth0/4(或select/3@false指出):
unique(X, L) :-
nth0(_, L, X, R),
\+ member(X, R).
nth0/4第四個(gè)參數(shù)R是刪除L元素的列表X。我們只是檢查那X不是R。
更好的版本
unique(X, L) :-
nth0(_, L, X, R),
maplist(dif(X), R).
這解決了@false指出的問(wèn)題,但是因?yàn)槟闶浅鯇W(xué)者我懷疑這對(duì)你很感興趣。
這具有在以下情況下工作的優(yōu)勢(shì):
?- unique(b, [X, Y, a]).
X = b,
dif(Y, b) ;
Y = b,
dif(X, b) ;
false.
TA貢獻(xiàn)1821條經(jīng)驗(yàn) 獲得超6個(gè)贊
這聽(tīng)起來(lái)像是一個(gè)家庭作業(yè)問(wèn)題。
嘗試這樣的事情。
unique(M, L) :- member(M, L), count(M, L, 1).??
count(M, [H|T], C) :- M = H, count(M, T, C1), C is C + 1.
...
完成后,這給...
?- unique(X, [1,2,3,1,3,2,5,4,3,8]).
X = 5 ;
X = 4 ;
X = 8 ;
false.
unique(Item, List) :-
? select(Item, List, L2),
? \+ member(Item, L2).
- 3 回答
- 0 關(guān)注
- 497 瀏覽
添加回答
舉報(bào)
