注册 登录
编程论坛 C++教室

双向循环链表排序?

zcdjt 发布于 2015-05-12 18:43, 706 次点击
//双向链表实现二十个数从小到大排序
#include<iostream>
using namespace std;
struct list
{
   int data;
   list *lLink,*rLink;
};
void List(int n)
{
  int temp;
  list *p,*q,*front;
  front=p=new list;
  p->rLink=p->lLink=p;
  int x;
  cout<<"请输入数字:";
  for(int i=0;i<n;i++)
  {
     cin>>x;
   for(p=front;p->rLink!=front&&p->data<x;p=p->rLink)//这儿有问题,在一些情况下不能排序,谁有好方法请指教。
   ;
   q=new list;
   
    q->data=x;
    q->lLink=p;
    q->rLink=p->rLink;
    p->rLink->lLink=q;
    p->rLink=q;
     
   }
   
   cout<<"从小到大输出为:";
   p=front;
   while(p->rLink!=front)
   {
     cout<<p->data<<" ";
     p=p->rLink;
   }
}
int main()
{
List(3);
system("pause");
return 0;
}
2 回复
#2
zcdjt2015-06-06 10:36
//双向链表实现二十个数从小到大排序
#include<iostream>
using namespace std;
struct list
{
   int data;
   list *lLink,*rLink;
};

int main()
{

  list *p,*q,*front;
  front=p=new list;
  p->rLink=p->lLink=p;
  int x;
  cout<<"请输入数字:";
  for(int i=0;i<6;i++)
  {
     cin>>x;
     p=front;
     while(p->rLink!=front&&p->rLink->data<x)
    p=p->rLink;
    q=new list;  
    q->data=x;
    q->lLink=p;
    p->rLink->lLink=q;
    q->rLink=p->rLink;
    p->rLink=q;   
   }
   

cout<<"从小到大输出为:";
   p=front->rLink;
   while(p!=front)
   {
     cout<<p->data<<" ";
     p=p->rLink;
   }
system("pause");
return 0;
}
#3
yangfrancis2015-06-06 11:46
while(p->rLink!=front&&p->rLink->data<x)
第一次执行循环的时候data没有初值这个条件怎么判断法?
像这种功能单向链表感觉应该已够了.你自己试一下不用lLink看成不成。
不过一楼代码的for循环好像有点不妥,如果输入值小于头结点front是不是还能顺利排序?
1