十大排序之归并排序(详解)

news/2024/5/17 19:32:05 标签: 排序算法, 算法, 归并排序

文章目录

  • 🐒个人主页
  • 🏅算法思维框架
    • 📖前言:
  • 🎀归并排序 时间复杂度O(n*logn)
      • 🎇1. 算法步骤思想
      • 🎇2、动画演示
      • 🎇3.代码实现

🐒个人主页

🏅算法思维框架

📖前言:

本篇博客主要以介绍十大算法>排序算法中的归并排序,有详细的图解、动画演示、良好的代码注释,帮助加深对这些算法的理解,进行查漏补缺~

🎀归并排序 时间复杂度O(n*logn)

归并排序(Merge sort) 是建立在归并操作上的一种有效的算法>排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。

🎇1. 算法步骤思想

  1. 申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列;
  2. 设定两个指针,最初位置分别为两个已经排序序列的起始位置;
  3. 比较两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置;
  4. 重复步骤 3 直到某一指针达到序列尾;
  5. 将另一序列剩下的所有元素直接复制到合并序列尾。

🎇2、动画演示

在这里插入图片描述

🎇3.代码实现

  private int[] temp;//帮助两个区间排序
    public  void sort(int[] arr){
        if(arr==null||arr.length<2){
            return;
        }
        //思路:将数组分为左右区间,分别进行排序,后使用merge()融合
        temp=new int[arr.length];//创建一个辅助数组来帮助各区间排序
        sortDG(arr,0,arr.length-1);
    }
    private void  sortDG(int[] arr,int left,int right){
        if(left==right){
            return;
        }
        int mid=left+(right-left)/2;
        sortDG(arr,0,mid);
        sortDG(arr,mid+1,right);
        //后序位置,进行两个已经排好序的数组的融合操作
        merge(arr,left,mid,right);

    }
    private void merge(int[] arr,int left,int mid,int right){
        for (int i = left; i <=right ; i++) {//先把原数组arr[]中待排序区间【left,right】寄存在temp[]对应区间内
            temp[i]=arr[i];
        }
        //使用双索引将temp[]寄存区间的值进行排序后回填到arr[]的【left,right】区间内
       int index=left;
        int i=left;
        int j=mid+1;
        while (index<=right){
            if(i>mid){
                arr[index++]=temp[j++];
            }else if(j>right){
                arr[index++]=temp[i++];
            }else if(arr[i]<arr[j]){
                arr[index++]=temp[i++];
            }else if(arr[i]>=arr[j]){
                arr[index++]=temp[j++];
            }
        }
    }

http://www.niftyadmin.cn/n/5212887.html

相关文章

【腾讯云云上实验室-向量数据库】用向量数据库——实现高效文本检索功能

文章目录 前言Tencent Cloud VectorDB 简介Tencent Cloud VectorDB 使用实战申请腾讯云向量数据库腾讯云向量数据库使用步骤腾讯云向量数据库实现文本检索 结论和建议 前言 想必各位开发者一定使用过关系型数据库MySQL去存储我们的项目的数据&#xff0c;也有部分人使用过非关…

vs2015如何远程启动程序来进行调试

vs远程调试的方式有两种&#xff0c;远程启动方式和附加进程方式。   一般来说&#xff0c;咱们使用vs调试代码时&#xff0c;直接附加进程即可&#xff0c;但某些时候附加进程方式无法命中断点。比如我们想调试的C代码&#xff0c;但是调试的入口程序是C#程序&#xff0c;如…

物流公司打印用什么软件,佳易王物流运单打印管理系统软件下载

物流公司打印用什么软件&#xff0c;佳易王物流运单打印管理系统软件下载 软件特色&#xff1a; 1、功能实用&#xff0c;操作简单&#xff0c;不会电脑也会操作&#xff0c;软件免安装&#xff0c;已内置数据库。 2、物流开单打印&#xff0c;可以打印两联单或三联单&#x…

【spring(五)】SpringMvc总结 SSM整合流程

目录 一、SpringMVC简介&#xff1a; 二、SpringMVC快速入门&#xff1a; 三、SpringMVC bean的管理&#xff1a;⭐ ①配置bean ②扫描bean 四、SpringMVC配置类&#xff1a;⭐ 五、SpringMVC 请求与响应 六、SpringMVC REST风格 七、SSM整合 异常处理&#xff1a; 八、…

vite和webpack的区别和练习

Vite和Webpack都是现代化的前端构建工具&#xff0c;但它们之间存在一些区别&#xff1a; 构建性能&#xff1a;Vite使用ES Modules提高了构建性能&#xff0c;可以在构建时只构建需要的部分&#xff0c;而Webpack则需要在构建时处理整个应用程序。 开发体验&#xff1a;Vite具…

浙大提出KnowPAT框架:大模型的知识偏好对齐与垂域应用

©PaperWeekly 原创 作者 | 张溢弛 单位 | 浙江大学计算机科学与技术学院 研究方向 | 知识图谱、大语言模型 前言 将大语言模型&#xff08;LLM&#xff09;用于垂直领域完成问答&#xff08;QA&#xff09;、对话&#xff08;Dialogue&#xff09;等任务是当前大语言模型…

【Python 训练营】N_8 打印阿姆斯特朗数

题目 输入一个数&#xff0c;判断是否为阿姆斯特朗数&#xff0c;阿姆斯特朗数指一个n位正整数等于其各位数字的n次方之和。其中n为3时是水仙花数。 分析 利用循环&#xff0c;获取数的长度&#xff0c;根据长度和定义&#xff0c;拆分出来运算 答案 while True:n int(in…

问题记录--sscanf踩内存

1. 问题描述 使用sscanf函数将字符串对变量赋值的时候&#xff0c;会把当前变量地址后面的变量内容修改掉。 1. 变量定义 uint8_t TargetType 0x00; //0x00 WallE; 0x01 Elin uint8_t val 0; //string lengthuint8_t SLAVE_ADDR 0x4C; uint8_t TxData[12] { 0x00};uin…