C语言已知线性表存储在带头结点的单链表head中,请设计算法函数,将head中的结点按结点值升序排列。
时间: 2024-05-04 19:18:53 浏览: 273
可以使用冒泡排序或插入排序等算法对链表进行排序。下面是使用插入排序的算法实现:
```c
typedef struct Node { // 定义链表结点
int data;
struct Node* next;
} Node;
void insert_sort(Node** head) {
Node *p, *q, *r, *s;
p = (*head)->next; // p指向第一个结点
(*head)->next = NULL; // 将原链表置为空链表
while (p != NULL) { // 遍历原链表
r = p; // r指向待插入结点
p = p->next; // p指向下一个待插入结点
s = *head; // s指向新链表
while (s != NULL) { // 在新链表中查找插入位置
if (s->next == NULL || s->next->data > r->data) {
q = s->next; // q指向s的后继结点
s->next = r; // 将r插入到s和q之间
r->next = q;
break;
}
s = s->next; // s指向下一个结点
}
}
}
```
该算法使用了头插法构建新链表,遍历原链表中的每个结点,将其插入到新链表中的合适位置。时间复杂度为 O(n^2)。
阅读全文