Go最新链表排序算法(1),Golang开发最佳实践手册全网独一份

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

common.h

typedef struct Node LNode;

struct Node {
    int data;
    LNode *next;
    LNode *prev;
};
备注:以下排序算法默认由小到大排序

链表排序需要注意保证链表节点直接的连续性

  • 直接插入排序
算法简介
  1. 第一个链表节点,可以认为是已排序好;
  2. 从第二个节点开始进行排序操作,逐一向前遍历,对比节点值大小,遍历至第一个比它的值小的节点,把待排序节点插入到该节点后面;
  3. 依次对后续所有节点重复第2步操作,直至操作到最后一个节点。
算法实现
LNode\* insert\_sort(LNode \*p)
{
 if(NULL == p) return p;

 LNode \*tmp = NULL; //指向待排序节点,用于节点插入
 LNode \*q = p, \*t = q->next;// q指向待排序节点的前一个节点,t指向待排序节点
 while(t)
 {
 if(q->data < t->data)
 {
 tmp = t;
 t = t->next;
 if(t)
 {
 t->prev = q;
 }
 q->next = t;
 while(q && (q->data < tmp->data))
 {
 q = q->prev;
 }
 if(q)
 {
 tmp->next = q->next;
 q->next->prev = tmp;
 q->next = tmp;
 tmp->prev = q;
 }
 else
 {
 tmp->next = p;
 tmp->prev = NULL;
 p->prev = tmp;
 p = tmp;
 }
 if(t)
 {
 q = t->prev;
 }
 }
 else
 {
 t = t->next;
 q = q->next;
 }
 }

 return p;
}
  • 归并排序

算法简介

归并排序采用分治思想,首先使其子序列成为有序序列,然后再对子序列进行归并。

递归实现:

  1. 首先把链表分割为两个子链表(采用快慢指针找到链表中间节点),递归该分割过程,直至子链表只包含一个节点为止;
  2. 创建一个新的链表节点,指向排序好的链表;对分割得到的两个子链表逐一遍历对比,值小的节点插入到新链表后面;
  3. 两个子链表归并完成,且已完成对其排序,返回链表头指针给上层递归。
算法实现
LNode *list_split(LNode *head) //分割链表,返回后一个子链表的头指针
{
    if(NULL == head)
    {
        return head;
    }

    LNode *tmp = head;
    LNode *slow = head, *fast = head; //快慢指针找到原链表的中间节点
    while(fast)
    {
        fast = fast->next;
        if(fast)
        {
            fast = fast->next;
        }

        if(NULL == fast)
        {
            break;
        }
        slow = slow->next;
    }



![img](https://img-blog.csdnimg.cn/img_convert/ef3639815b8880ff54b8442d082295bb.png)
![img](https://img-blog.csdnimg.cn/img_convert/4b8d38d050b9884da43a05b49c0295f7.png)

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化的资料的朋友,可以添加戳这里获取](https://bbs.csdn.net/topics/618658159)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

需要这份系统化的资料的朋友,可以添加戳这里获取](https://bbs.csdn.net/topics/618658159)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 9
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值