一步一步写算法(之链表排序)
2014-12-11 09:20
169 查看
原文:
一步一步写算法(之链表排序)
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】
相比较线性表的排序而言,链表排序的内容稍微麻烦一点。一方面,你要考虑数据插入的步骤;另外一方面你也要对指针有所顾虑。要是有一步的内容错了,那么操作系统会马上给你弹出一个exception。就链表的特殊性而言,适合于链表的排序有哪些呢?
(1)插入排序 (适合)
(2)冒泡排序 (适合)
(3)希尔排序 (适合)
(4)选择排序 (适合)
(5)快速排序 (不适合)
(6)合并排序 (不适合)
(7)基数排序 (不适合)
(8)堆排序 (不适合)
其实,一般来说。如果涉及到数据之间的相对关系调配,那么只适合线性排序;如果只是数据内容之间的相互交换,那么这种排序方法也比较适合链表的排序。快速排序、合并排序、堆排序都涉及到了中间值的选取问题,所以不大适合链表排序。
为了说明链表排序是怎么进行的,我们可以利用插入排序作为示例,描述链表是怎么进行插入排序的。
a)首先遍历节点,一边是排序好的节点,一边是待排序的节点
b)对于待插入的节点,选择合适的位置插入即可
一步一步写算法(之链表排序)
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】
相比较线性表的排序而言,链表排序的内容稍微麻烦一点。一方面,你要考虑数据插入的步骤;另外一方面你也要对指针有所顾虑。要是有一步的内容错了,那么操作系统会马上给你弹出一个exception。就链表的特殊性而言,适合于链表的排序有哪些呢?
(1)插入排序 (适合)
(2)冒泡排序 (适合)
(3)希尔排序 (适合)
(4)选择排序 (适合)
(5)快速排序 (不适合)
(6)合并排序 (不适合)
(7)基数排序 (不适合)
(8)堆排序 (不适合)
其实,一般来说。如果涉及到数据之间的相对关系调配,那么只适合线性排序;如果只是数据内容之间的相互交换,那么这种排序方法也比较适合链表的排序。快速排序、合并排序、堆排序都涉及到了中间值的选取问题,所以不大适合链表排序。
为了说明链表排序是怎么进行的,我们可以利用插入排序作为示例,描述链表是怎么进行插入排序的。
a)首先遍历节点,一边是排序好的节点,一边是待排序的节点
void sort_for_link_node(NODE** ppNode) { NODE* prev; NODE* curr; if(NULL == ppNode || NULL == *ppNode) return; curr = (*ppNode) ->next; (*ppNode) ->next = NULL; while(curr){ prev = curr; curr = curr->next; insert_for_sort_operation(ppNode, prev); } return; }
b)对于待插入的节点,选择合适的位置插入即可
void insert_for_sort_operation(NODE** ppNode, NODE* pNode) { NODE* prev; NODE* cur; /* 在第一个数据之前插入pNode */ if(pNode->data < (*ppNode)->data){ pNode->next = *ppNode; *ppNode = pNode; return; } cur = *ppNode; while(cur){ if(pNode->data < cur->data) break; prev = cur; cur = cur->next; } pNode->next = prev->next; prev->next = pNode; return; }
相关文章推荐
- 一步一步写算法(之链表排序)
- 一步一步写算法(之链表排序)
- 一步一步写算法(之链表排序)
- 一步一步写算法(之链表排序)
- 一步一步写算法(之链表排序)
- 每天一算法(把二元查找树转变成排序的双向链表 )
- 一步一步写算法(之快算排序)
- 怎样编写一个程序,把一个有序整数数组放到二叉树中? 编写实现链表排序的一种算法。说明为什么你会选择用这样的方法?
- 一步一步复习数据结构和算法基础-链表(3)
- 一步一步复习数据结构和算法基础-链表(2)
- 把二元查找树转变成排序的双向链表--算法001
- 一步一步写算法(之链表的删除与插入)
- 中序线索二叉树算法 解决 把二元查找树转变成排序的双向链表
- 【数据结构与算法基础】单链表及其应用基数排序 / Singly Linked List and radix sort
- 一步一步写算法(之基数排序)
- SortedList排序列表 算法实现 -- (实现了两个有序链表的归并排序功能)
- 把二元查找树转变成排序的双向链表——精选微软经典的算法面试100题中第一题
- 链表的归并排序:来自STL_ list_ sort 算法
- 一步一步写算法(之链表重合)
- 微软等数据结构+算法面试100题(43)-- 把二元查找树转变成排序的双向链表