直接上代码
1 -module(bubblesort). 2 -export([start/1]). 3 4 start(List) -> 5 SortedList = sort(List, []), 6 io:format("SortedList:~w~n", [SortedList]). 7 8 %% 冒泡算法:每次step得到一个最大值,对余下的列表再进行递归调用 9 sort([], SortedList) -> 10 SortedList; 11 sort(List, SortedList) -> 12 {Max, T} = step(List), 13 sort(T, [Max] ++ SortedList). 14 15 %% 将列表的第一个元素作为最大值与列表中的其它元素进行比较 16 step([H|T]) -> 17 step(H, T, []). 18 19 %% 得到最大值 20 step(Max, [], T1) -> 21 {Max, T1}; 22 step(Max, [H|T], T1) -> 23 if 24 Max >= H -> step(Max, T, [H] ++ T1); 25 Max < H -> step(H, T, [Max] ++ T1) 26 end.
附注:
在网上看见一段计算九九乘法表的代码,摘录如下
1 foo() -> foo(1,1). 2 foo(9,9) -> io:format("~p*~p=~p \n",[9,9,9*9]); 3 foo(X,X) -> io:format("~p*~p=~p \n",[X,X,X*X]),foo(1,X+1); 4 foo(X,Y) -> io:format("~p*~p=~p ",[X,Y,X*Y]),foo(X+1,Y).
我称之为回车换行算法,精妙之处在于第3行foo(1,X+1),1表示回车,第一个乘法因子从1开始计算,X+1表示换行,第二个乘法因子递加1