C++中怎么对链表进行插入式排序?
例如:链表中插入数据的同时进行排序,用指针怎么做?英文名叫insertsortlinkedlist...
例如:链表中插入数据的同时进行排序,用指针怎么做?
英文名叫insert sort linked list 展开
英文名叫insert sort linked list 展开
1个回答
展开全部
#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;
}
#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;
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询