一步一步写算法(之链表排序)
2014-04-11 19:19
246 查看
原贴地址:http://blog.csdn.net/feixiaoxing/article/details/6905260
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】
相比较线性表的排序而言,链表排序的内容稍微麻烦一点。一方面,你要考虑数据插入的步骤;另外一方面你也要对指针有所顾虑。要是有一步的内容错了,那么操作系统会马上给你弹出一个exception。就链表的特殊性而言,适合于链表的排序有哪些呢?
(1)插入排序 (适合)
(2)冒泡排序 (适合)
(3)希尔排序 (适合)
(4)选择排序 (适合)
(5)快速排序 (不适合)
(6)合并排序 (不适合)
(7)基数排序 (不适合)
(8)堆排序 (不适合)
其实,一般来说。如果涉及到数据之间的相对关系调配,那么只适合线性排序;如果只是数据内容之间的相互交换,那么这种排序方法也比较适合链表的排序。快速排序、合并排序、堆排序都涉及到了中间值的选取问题,所以不大适合链表排序。
为了说明链表排序是怎么进行的,我们可以利用插入排序作为示例,描述链表是怎么进行插入排序的。
a)首先遍历节点,一边是排序好的节点,一边是待排序的节点
[cpp] view
plaincopy
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)对于待插入的节点,选择合适的位置插入即可
[cpp] view
plaincopy
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;
}
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】
相比较线性表的排序而言,链表排序的内容稍微麻烦一点。一方面,你要考虑数据插入的步骤;另外一方面你也要对指针有所顾虑。要是有一步的内容错了,那么操作系统会马上给你弹出一个exception。就链表的特殊性而言,适合于链表的排序有哪些呢?
(1)插入排序 (适合)
(2)冒泡排序 (适合)
(3)希尔排序 (适合)
(4)选择排序 (适合)
(5)快速排序 (不适合)
(6)合并排序 (不适合)
(7)基数排序 (不适合)
(8)堆排序 (不适合)
其实,一般来说。如果涉及到数据之间的相对关系调配,那么只适合线性排序;如果只是数据内容之间的相互交换,那么这种排序方法也比较适合链表的排序。快速排序、合并排序、堆排序都涉及到了中间值的选取问题,所以不大适合链表排序。
为了说明链表排序是怎么进行的,我们可以利用插入排序作为示例,描述链表是怎么进行插入排序的。
a)首先遍历节点,一边是排序好的节点,一边是待排序的节点
[cpp] view
plaincopy
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)对于待插入的节点,选择合适的位置插入即可
[cpp] view
plaincopy
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;
}
相关文章推荐
- 一步一步写算法(之链表排序)
- 一步一步写算法(之链表排序)
- 一步一步写算法(之链表排序)
- 一步一步写算法(之链表排序)
- 一步一步写算法(之链表排序)
- 一步一步写算法(之创建顺序链表)
- 微软等数据结构+算法面试100题(43)-- 把二元查找树转变成排序的双向链表
- 二元查找树转变成排序的双向链表之C#算法实现
- 每天一道算法题(8)——把二元查找树转变成排序的双向链表
- 每日一道算法题1 ——把二元查找树转变成排序的双向链表
- iOS 算法面试题(冒泡排序、选择排序、链表逆序)~demo
- 基本的排序算法之—— 冒泡排序(稳定)(对于固定的内存空间数组或顺序表,对于单链表也可以)
- 插入排序——一步一步算法篇
- 算法-连接两条排序的链表
- Java学习之数组1(1.数组的声明;2.元素为引用数据类型的数组;3.关于main方法里的String[] args;4.数组排序;5.数3退1 数组算法,(用数组模拟链表);6数组查找之二分法;7数组的拷贝)
- 二元查找树转变成排序的双向链表之C#算法实现
- [学习总结][算法]用插入排序对一个链表进行排序
- [算法]作死的链表排序
- 校招准备系列:每天一道算法题(14)-合并两个排序的链表
- 每天一道算法题(8)——把二元查找树转变成排序的双向链表