C++中怎么对链表进行插入式排序?

例如:链表中插入数据的同时进行排序,用指针怎么做?英文名叫insertsortlinkedlist... 例如:链表中插入数据的同时进行排序,用指针怎么做?
英文名叫insert sort linked list
展开
 我来答
严显敏
2015-07-12 · TA获得超过270个赞
知道答主
回答量:132
采纳率:50%
帮助的人:36万
展开全部
#include <iostream>
#include <iomanip>
#include <cstdlib>

using namespace std;

struct node
{
int item;
node *next;
node(int x, node* t)
{
item = x;
next = t;
}
};

typedef node *link;

link reverse(link x)
{
link t, y=x, r=0;
while(y!=0)
{
t = y->next;
y->next = r;
r = y;
y = t;
}
return r;
}

static const int N = 100;

int main()
{
node heada(0, 0);
link pa = &heada, walkera = pa;
for(int i=0; i<N; i++) //生成随机链表序列
{
walkera = (walkera->next = new node(rand() % 1000, 0));
}

node headb(0, 0);
link pb=&headb, walkerb, x;
//根结点b指向链表a中的节点,不需要重新生成结点
for(walkera = pa->next; walkera != 0; walkera = x) //遍历链表a
{
x = walkera->next;
for(walkerb=pb; walkerb->next !=0; walkerb=walkerb->next) //遍历链表b
if(walkerb->next->item > walkera->item) break; //下一个结点的值比要插入的结点的值大就跳出
walkera->next = walkerb->next;
walkerb->next = walkera;
}

walkerb = pb;
while(walkerb->next != 0)
{
cout << setw(5) << walkerb->item;
walkerb = walkerb->next;
}

return 0;
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式