给定Erlang中的任何列表,例如:

L = [foo, bar, foo, buzz, foo].


如何使用递归函数仅显示该列表的唯一项?
我不想使用内置函数,例如列表函数之一(如果存在)。

在我的示例中,我想要到达的是一个新列表,例如

SL = [bar, buzz].


我的猜测是,在应用过滤器之前,我会先使用快速排序功能对列表进行排序吗?

任何的意见都将会有帮助。该示例是Cesarini和Thompson出色的“ Erlang编程”书第3章中练习的一种变体。

最佳答案

我建议这一点:

unique(L) ->
    unique([],L).
unique(R,[]) -> R;
unique(R,[H|T]) ->
    case member_remove(H,T,[],true) of
        {false,Nt} -> unique(R,Nt);
        {true,Nt} -> unique([H|R],Nt)
    end.

member_remove(_,[],Res,Bool) -> {Bool,Res};
member_remove(H,[H|T],Res,_) -> member_remove(H,T,Res,false);
member_remove(H,[V|T],Res,Bool) -> member_remove(H,T,[V|Res],Bool).


member_remove函数在一次通过中返回剩余的尾部,而没有检查所有重复出现的元素和测试结果。

07-24 09:24