Erlang实现排序算法

使用Erlang实现简单的排序算法:快速排序,冒泡排序,插入排序

-module(list_sort).
 
-export([qsort/1,
         bubble_sort/1,
         insert_sort/1
        ]).
 
qsort([]) -> [];
qsort([Pivot|T]) ->
    qsort([X || X <- T,X < Pivot])
    ++ [Pivot] ++
        qsort([X || X <-T,X >= Pivot]).
%%@spec bubble_sort/1
bubble_sort(L) -> bubble_sort(L,len(L)).
bubble_sort(L,1) -> L;
bubble_sort([H|T],N) -> 
    Result = bubble_once(H,T),
    io:format("Result is  ~p~n",[Result]),
    bubble_sort(Result,N-1).
 
bubble_once(H,[]) -> [H];
bubble_once(X,[H|T]) ->
    if X > H ->
            [H|bubble_once(X,T)];
        true ->
            [X|bubble_once(H,T)]
    end.
 
len([]) -> 0;
len([_H|T]) -> 1 + len(T).
 
%%@spec insert_sort/1
insert_sort(L) -> insert_sort([],L).
insert_sort(L,[]) -> L;
insert_sort(L,[H|T]) ->
    insert_sort(normal(H,L),T).
 
normal(X,[]) -> [X];
normal(X,[H|T]) ->
    if X > H ->
            [H|normal(X,T)];
        true ->
            [X|[H|T]]
    end.

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是Erlang实现选择排序的代码和解释: ```erlang selection_sort(List) -> selection_sort(List, []). selection_sort([], Acc) -> Acc; selection_sort(List, Acc) -> {Min, Rest} = find_min(List), selection_sort(Rest, [Min | Acc]). find_min([H | T]) -> find_min(T, H, []). find_min([], Min, Rest) -> {Min, Rest}; find_min([H | T], Min, Rest) when H < Min -> find_min(T, H, [Min | Rest]); find_min([H | T], Min, Rest) -> find_min(T, Min, [H | Rest]). ``` 这里的选择排序算法使用了递归的方式实现。`selection_sort/1`函数是对外暴露的接口,它调用了`selection_sort/2`函数,并将一个空列表作为累加器传递给它。`selection_sort/2`函数有两个参数,第一个参数是待排序的列表,第二个参数是累加器。当待排序的列表为空时,`selection_sort/2`函数返回累加器。否则,它调用`find_min/1`函数查找列表中的最小元素,并将其插入到累加器的头部。然后,它递归调用自身,将剩余的元素和更新后的累加器作为参数传递给自己。 `find_min/1`函数用于查找列表中的最小元素。它调用了`find_min/3`函数,并将第一个元素作为初始最小值传递给它。`find_min/3`函数有三个参数,第一个参数是待查找的列表,第二个参数是当前的最小值,第三个参数是一个累加器,用于存储比当前最小值小的元素。当待查找的列表为空时,`find_min/3`函数返回当前的最小值和累加器。否则,它比较当前元素和当前最小值的大小,如果当前元素比当前最小值小,则将当前元素作为新的最小值,并将当前最小值插入到累加器的头部。然后,它递归调用自身,将剩余的元素、新的最小值和更新后的累加器作为参数传递给自己。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值