对链表使用插入排序的C语言实现示例

这篇具有很好参考价值的文章主要介绍了对链表使用插入排序的C语言实现示例。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

#include <stdio.h>
#include <stdlib.h>

// 定义链表节点结构体
struct ListNode {
    int val;
    struct ListNode *next;
};

// 插入排序函数
struct ListNode* insertionSortList(struct ListNode* head) {
    if (head == NULL || head->next == NULL) {
        return head;
    }

    struct ListNode dummy;
    dummy.next = NULL;
    struct ListNode* current = head;

    while (current != NULL) {
        struct ListNode* prev = &dummy;
        struct ListNode* nextNode = current->next;

        // 在已排序的链表中找到插入位置
        while (prev->next != NULL && prev->next->val < current->val) {
            prev = prev->next;
        }

        // 插入当前节点
        current->next = prev->next;
        prev->next = current;

        // 继续处理下一个节点
        current = nextNode;
    }

    return dummy.next;
}

// 创建新节点
struct ListNode* createNode(int val) {
    struct ListNode* newNode = (struct ListNode*)malloc(sizeof(struct ListNode));
    newNode->val = val;
    newNode->next = NULL;
    return newNode;
}

// 打印链表
void printList(struct ListNode* head) {
    struct ListNode* current = head;
    while (current != NULL) {
        printf("%d ", current->val);
        current = current->next;
    }
    printf("\n");
}

// 释放链表节点的内存
void freeList(struct ListNode* head) {
    struct ListNode* current = head;
    while (current != NULL) {
        struct ListNode* temp = current;
        current = current->next;
        free(temp);
    }
}

int main() {
    // 创建示例链表: 4 -> 2 -> 1 -> 3
    struct ListNode* head = createNode(4);
    head->next = createNode(2);
    head->next->next = createNode(1);
    head->next->next->next = createNode(3);

    printf("Original list: ");
    printList(head);

    // 对链表进行插入排序
    head = insertionSortList(head);

    printf("Sorted list: ");
    printList(head);

    // 释放链表节点的内存
    freeList(head);

    return 0;
}

在这个示例中,我们定义了 insertionSortList 函数用于对链表进行插入排序。然后,在 main 函数中创建了示例链表,调用 insertionSortList 函数进行排序,并打印结果。最后,释放了链表节点的内存。

插入排序的时间复杂度为O(n^2),在某些情况下比归并排序的O(nlogn)更有效。

  1. 特殊情况处理: 首先,我们检查链表是否为空或者只有一个节点。如果是这样,那么链表已经是有序的,不需要进行排序,直接返回原链表。

  2. 创建一个哑节点: 我们创建一个名为 dummy 的哑节点,它的作用是作为新链表的头部。这样做的好处是,哑节点可以简化插入操作的边界情况处理,同时也可以减少对头节点是否变化的判断。

  3. 遍历链表: 我们使用一个指针 current 来遍历原始链表。在每次迭代中,我们将 current 指向的节点从原始链表中取下,准备将其插入到新链表中。

  4. 在新链表中找到插入位置: 我们需要在新链表中找到正确的插入位置,使得新节点能够保持有序。为了做到这一点,我们从哑节点开始,沿着新链表向后遍历,直到找到插入位置或者到达链表末尾。

  5. 插入节点: 一旦找到了正确的插入位置,我们就将当前节点插入到新链表中。具体操作是,将当前节点的 next 指针指向插入位置节点的下一个节点,然后将插入位置节点的 next 指针指向当前节点。这样就成功地将当前节点插入到了新链表中。

  6. 继续遍历: 接着,我们继续遍历原始链表,重复上述步骤,直到所有节点都被插入到了新链表中。

  7. 返回结果: 最后,我们返回新链表的头部,即哑节点的下一个节点,作为排序后的链表。

在代码中,我们用 struct ListNode* prev 来记录当前节点在新链表中的插入位置的前一个节点,这样可以更方便地进行插入操作。另外,我们使用了一个 nextNode 指针来保存当前节点的下一个节点,以便在插入操作后继续遍历原始链表。

 文章来源地址https://www.toymoban.com/news/detail-830056.html

到了这里,关于对链表使用插入排序的C语言实现示例的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 插入排序-C语言实现

            🍔在学数据结构的第一节课就知道了数据结构课程是要管理并且学会操作数据,当然操作数据首先想到的就是数据的排序,排过顺序的数据的使用价值才够大。前面我们学习了顺序表也学习了链表等等,这些就是储存数据的方法,下面我们来看一看插入排序的特

    2024年02月09日
    浏览(33)
  • Java高级语言实现插入排序算法

    【引言】 插入排序算法是一种简单且常用的排序算法。它通过依次将未排序的元素插入已排序序列中的正确位置来达到排序的目的。本文将使用Java高级语言实现插入排序算法,并讲解其核心思想和代码实现。 【算法思想】 插入排序的核心思想是通过构建有序序列,对于未排

    2024年02月11日
    浏览(46)
  • 用C语言实现插入排序算法

    1.设计思路 用插入排序对长度为n的待排序数组A进行排序的伪代码(在代码中,A中元素的数目n用A.length来表示)。 伪代码如下: 2.源代码 3.运行结果 第一行的5为要排序的元素个数,12,32,6,67,43为要排序的数,排序过程为6插到最前面,43插到67前面,即可完成从小到大的

    2024年02月14日
    浏览(42)
  • 【C语言】解析C语言实现排序的算法(冒泡排序、插入排序、选择排序、快速排序、归并排序)

    本博客主要围绕五种常见的排序算法展开讨论,包括选择排序、快速排序、归并排序、冒泡排序和插入排序。针对每种算法,我对其思想、特点、时间复杂度、稳定性以及优缺点进行了详细解释和比较。 冒泡排序算法是一种简单且常用的排序算法。它通过重复地交换相邻的元

    2024年02月13日
    浏览(41)
  • 数据结构——C语言实现常见排序(插入排序、希尔排序、选择排序、堆排序、冒泡排序)

    现在是北京时间2023年6月23日13点19分,度过了一个非常愉快的端午节。由于刚从学校回家,一下子伙食强度直升了个两三个档次。这也导致我的肠胃不堪重负,我也准备等会去健身房消耗一下盈余的热量。回到家陪伴爷爷走人生最后的阶段才是我这个暑假最重要的事情。自从

    2024年02月10日
    浏览(49)
  • 力扣hot100 排序链表 归并排序 递归

    Problem: 148. 排序链表 👩‍🏫 参考 ⏰ 时间复杂度: O ( n ) O(n) O ( n ) 🌎 空间复杂度: O ( n ) O(n) O ( n )

    2024年01月25日
    浏览(40)
  • 数据结构__<八大排序> __插入排序 |希尔排序 |选择排序 |堆排序 |快速排序 |归并排序(C语言实现)

    目录 插入排序  希尔排序 选择排序 堆排序 冒泡排序 快速排序 hoare法 挖坑法 前后指针法 快排特性总结 三数取中优化 小区间优化 快排非递归 归并排序 归并排序非递归 计数排序 总结 OJ测试 1、元素集合越接近有序,直接插入排序算法的时间效率越高 2、时间复杂度:O(N^2

    2023年04月09日
    浏览(81)
  • 【数据结构】—从直接插入排序升级到希尔排序究极详解(含C语言实现)

                                            食用指南:本文在有C基础的情况下食用更佳                                          🔥 这就不得不推荐此专栏了: C语言                                         ♈️ 今日夜电波:透明で透き通って何にでもなれそ

    2024年02月08日
    浏览(49)
  • Go 语言实现冒泡排序算法的简单示例

    以下是使用 Go 语言实现冒泡排序算法的简单示例: 在这个例子中, bubbleSort 函数接收一个整数切片,对切片中的元素进行冒泡排序。在 main 函数中,我们定义了一个示例数组,调用 bubbleSort 函数对其进行排序,并输出结果。 注意,冒泡排序算法的时间复杂度为 O(n^2),因此对

    2024年01月23日
    浏览(45)
  • Go 语言实现归并排序算法的简单示例(附上源码)

    以下是使用 Go 语言实现归并排序算法的简单示例: 在这个例子中, mergeSort 函数接收一个整数切片,使用递归的方式进行归并排序。 merge 函数用于合并两个已排序的切片。在 main 函数中,我们定义了一个示例数组,调用 mergeSort 函数对其进行排序,并输出结果。 归并排序算

    2024年01月21日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包