| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2536 人关注过本帖
标题:单链表排序问题
取消只看楼主 加入收藏
海风27
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2011-8-17
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:3 
单链表排序问题
struct node
{
    int ID;
    char name[10];
    int mark;
    struct node *next;
};
struct node *paixu()
{
    struct node *first,*max,*p,*p_max,*tail;
    if(head->next==NULL||head->next->next==NULL)
    {
        printf("无须排序!");
        getch();
        return head;
    }
    else
    {
        first=(struct node *)malloc(sizeof(node));
        first->next=NULL;
        max=head->next;
        p=head->next;
        while(head->next!=NULL)
        {
            for(max=head->next,p=head->next->next,p_max=head;p->next!=NULL;p=p->next)
            {
                if(p->next->mark>max->mark)
                {
                    p_max=p;
                    max=p->next;
                }
            }
            if(first->next==NULL)
            {
                first->next=max;
                tail=max;
            }
            else
            {
            tail->next=max;
            tail=max;
            }
            if(p->next!=NULL)
            {
                p_max->next=p->next;
            }
        }
        tail->next=NULL;
        head=first;
        return head;
    }
}
这是一个用来单链表排序的函数,能运行,但是进入死循环,不知道有什么问题,高手帮忙看下!

[ 本帖最后由 海风27 于 2011-8-17 11:03 编辑 ]
搜索更多相关主题的帖子: return 
2011-08-17 01:20
海风27
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2011-8-17
收藏
得分:0 
回复 4楼 jcw08120110
这个函数是用选择排序法对单链表排序,主要有三个步骤:1,找出原链表最大的节点max;2,把max列入有序链表中(first);3,让max离开原链表(head);
p_max指的是max的前一个节点,在让max离开原链表时要用到。
    可能用的方法是有点复杂,还请各位大侠多多指教。
2011-08-17 14:55
海风27
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2011-8-17
收藏
得分:0 
回复 8楼 laoyang103
谢了,
2011-08-17 20:04
海风27
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2011-8-17
收藏
得分:0 
回复 10楼 QQ346957135
多谢大侠出手相助,敢问大侠贵姓?

[ 本帖最后由 海风27 于 2011-8-19 01:08 编辑 ]
2011-08-19 00:14
快速回复:单链表排序问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.037801 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved