写一个代码实现 c 语言带头结点单链表排序从(1,2,3...n)变为(1,n-1,2,n-2,3,n-3...)n 可以为任意实数
时间: 2024-10-20 20:06:27 浏览: 13
为了实现这个功能,我们可以使用两个循环,一个用于遍历输入链表,另一个用于构建新的逆序穿插链表。这里是一个简单的C语言示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
// 定义链表结构体
typedef struct Node {
int data;
struct Node* next;
} Node;
// 插入节点函数
void insertNode(Node** head, int value) {
Node* newNode = (Node*)malloc(sizeof(Node));
newNode->data = value;
newNode->next = *head;
*head = newNode;
}
// 遍历链表并逆序穿插
void reverseInsert(Node** head, Node** tail) {
if (*head == NULL || *tail == NULL) return;
// 如果第一个链表为空,直接把第二个链表添加到结果
if (*head == NULL) {
insertNode(head, (*tail)->data);
return;
}
// 先将第一个链表的第一个节点插入
insertNode(head, (*tail)->data);
// 更新第一个链表和第二个链表的头尾指针
Node* newTail = *head;
*head = (*head)->next;
(*tail)->next = NULL; // 确保最后一个节点之后无节点
// 递归处理剩余的节点
reverseInsert(&(*head), &newTail);
}
// 打印链表
void printList(Node* head) {
while (head != NULL) {
printf("%d -> ", head->data);
head = head->next;
}
printf("NULL\n");
}
int main() {
// 创建链表示例,例如 1 -> 2 -> 3 -> ... -> n
Node* inputList = NULL;
for (int i = 1; i <= 5; ++i) {
insertNode(&inputList, i);
}
// 初始化结果链表头尾指针
Node* resultHead = NULL, *resultTail = NULL;
// 对输入链表进行逆序穿插排序
reverseInsert(&inputList, &resultTail);
// 输出排序后的链表
printf("Original List (1->2->3...%d):", inputList->data);
printList(inputList);
printf("\nSorted List (1->n-1->2->n-2...):");
printList(resultHead);
return 0;
}
```
这个程序会创建一个从1到n的链表,然后通过`reverseInsert`函数将其逆序穿插成期望的形式。注意,由于题目中提到n可以是任意实数,但在实际编码中通常只处理整数。如果你需要支持浮点数,你需要修改数据类型并相应调整比较逻辑。
阅读全文