一步一步写算法(之链表排序)

参考网站:http://blog.csdn.net/feixiaoxing/article/details/6905260


相比较线性表的排序而言,链表排序的内容稍微麻烦一点。一方面,你要考虑数据插入的步骤;另外一方面你也要对指针有所顾虑。要是有一步的内容错了,那么操作系统会马上给你弹出一个exception。就链表的特殊性而言,适合于链表的排序有哪些呢?

    (1)插入排序    (适合)

    (2)冒泡排序    (适合)

    (3)希尔排序    (适合)

    (4)选择排序    (适合)

    (5)快速排序    (不适合)

    (6)合并排序    (不适合)

    (7)基数排序     (不适合)

    (8)堆排序         (不适合)

    其实,一般来说。如果涉及到数据之间的相对关系调配,那么只适合线性排序;如果只是数据内容之间的相互交换,那么这种排序方法也比较适合链表的排序。快速排序、合并排序、堆排序都涉及到了中间值的选取问题,所以不大适合链表排序。

    为了说明链表排序是怎么进行的,我们可以利用插入排序作为示例,描述链表是怎么进行插入排序的。

    a)首先遍历节点,一边是排序好的节点,一边是待排序的节点

[cpp]  view plain copy
  1. void sort_for_link_node(NODE** ppNode)  
  2. {  
  3.     NODE* prev;  
  4.     NODE* curr;  
  5.   
  6.     if(NULL == ppNode || NULL == *ppNode)  
  7.         return;  
  8.   
  9.     curr = (*ppNode) ->next;  
  10.     (*ppNode) ->next = NULL;  
  11.   
  12.     while(curr){  
  13.         prev = curr;  
  14.         curr = curr->next;  
  15.         insert_for_sort_operation(ppNode, prev);  
  16.     }  
  17.   
  18.     return;  
  19. }  

     b)对于待插入的节点,选择合适的位置插入即可

[cpp]  view plain copy
  1. void insert_for_sort_operation(NODE** ppNode, NODE* pNode)  
  2. {  
  3.     NODE* prev;  
  4.     NODE* cur;  
  5.   
  6.     /* 在第一个数据之前插入pNode */  
  7.     if(pNode->data < (*ppNode)->data){  
  8.         pNode->next = *ppNode;  
  9.         *ppNode = pNode;  
  10.         return;  
  11.     }  
  12.   
  13.     cur = *ppNode;  
  14.     while(cur){  
  15.         if(pNode->data < cur->data)  
  16.             break;  
  17.   
  18.         prev = cur;  
  19.         cur = cur->next;  
  20.     }  
  21.   
  22.     pNode->next = prev->next;  
  23.     prev->next = pNode;  
  24.     return;  
  25. }  


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值