鱼C论坛

 找回密码
 立即注册
查看: 1384|回复: 0

[技术交流] 构建链表并排序

[复制链接]
发表于 2020-2-27 16:16:29 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
建立一个链表。将链表排序并输出。
#include <stdio.h>
#include <stdlib.h>

typedef struct Node
{
    int data;
    struct Node *next;
}LNode;

int main()
{
    int n;
    while(scanf("%d", &n) != EOF)
    {
        int i;
        int input;
        LNode *L;
        L = (LNode *)malloc(sizeof(LNode));
        L -> next = NULL;
        LNode *pre = L;
        LNode *p;
        for(i = 0; i < n; i++)
        {
            scanf("%d ", &input);
            p = (LNode *)malloc(sizeof(LNode));
            p -> next = NULL;
            p -> data = input;
            pre -> next = p;
            pre = p;
        }//创建链表
        
        //直接插入排序
        pre = L -> next;p = pre -> next;//pre指向p的前面
        LNode *ppre = L;//插入时与pre用于定位
        while(p != NULL)
        {
            if(p -> data >= pre -> data)
            {
                pre = p; p = p -> next;
            }
            else
            {
                LNode *t = pre;
                pre = ppre -> next;
                while(p -> data >= pre -> data)
                {
                    ppre = pre; pre = pre -> next;
                }
                t -> next = p -> next;
                p -> next = pre;
                ppre -> next = p;
                p = t -> next;
                pre = t;
                ppre = L;
            }
        }
        p = L -> next;
        for(i = 0; i < n; i++)
        {
            printf("%d ", p -> data);
            p = p -> next;
        }
        printf("\n");
    }
}
一定要给头结点也分配一个空间,否则会有非法访问的问题。


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-16 02:01

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表