本文共 1718 字,大约阅读时间需要 5 分钟。
链表归并排序是一种高效的排序算法,尤其适用于处理大量数据时。其核心思想是将数据分成两半,分别排序后再合并。以下是实现细节及代码解析。
LNode 结构体包含数据字段和指向下一个节点的指针。CreateList 函数用于读取数据并构建链表。p和q,完成链表的合并。CreateList 函数创建链表节点并读取数据。p和q,将两个有序链表合并成一个新的链表。#include#include typedef struct LNode { int data; struct LNode* next;} LNode*, LinkList;LinkList CreateList() { LinkList L; L = (LinkList)malloc(sizeof(LNode)); L->next = NULL; LNode *q = L; LNode *p; int x; scanf("%d", &x); while (x != 999) { p = (struct LNode*)malloc(sizeof(LNode)); p->data = x; p->next = NULL; q->next = p; q = p; scanf("%d", &x); } return L;}void main() { LinkList a = (LinkList)malloc(sizeof(LNode)); LinkList b = (LinkList)malloc(sizeof(LNode)); a = CreateList(); b = CreateList(); LinkList c = (LinkList)malloc(sizeof(LNode)); c->next = NULL; LNode *p = a->next; LNode *q = b->next; LNode *y; while (p != NULL && q != NULL) { if (p->data <= q->data) { y = p->next; p->next = c->next; c->next = p; p = y; } else { y = q->next; q->next = c->next; c->next = q; q = y; } } if (q) { p = q; while (p != NULL) { y = p->next; p->next = c->next; c->next = p; p = y; } } y = c->next; while (y != NULL) { printf("%d ", y->data); y = y->next; }}
该实现展示了链表归并排序的核心逻辑,适合处理大数据量的排序场景。
转载地址:http://wxiq.baihongyu.com/