当前位置:首页 > 科技  > 软件

聊聊C#归并排序算法

来源: 责编: 时间:2023-10-10 18:32:19 433观看
导读前言归并排序是一种常见的排序算法,它采用分治法的思想,在排序过程中不断将待排序序列分割成更小的子序列,直到每个子序列中只剩下一个元素,然后将这些子序列两两合并排序,最终得到一个有序的序列。归并排序实现原理将待排

前言

归并排序是一种常见的排序算法,它采用分治法的思想,在排序过程中不断将待排序序列分割成更小的子序列,直到每个子序列中只剩下一个元素,然后将这些子序列两两合并排序,最终得到一个有序的序列。BH128资讯网——每日最新资讯28at.com

归并排序实现原理

  1. 将待排序序列分割成两个子序列,直到每个子序列中只有一个元素。
  2. 将相邻的两个子序列合并,并按照大小顺序合并为一个新的有序序列。
  3. 不断重复第2步,直到所有子序列都合并为一个有序序列。

归并排序代码实现

public static void MergeSort(int[] arr, int left, int right)        {            if (left < right)            {                // 计算中间索引                int mid = (left + right) / 2;                // 对左半部分数组进行归并排序                MergeSort(arr, left, mid);                // 对右半部分数组进行归并排序                MergeSort(arr, mid + 1, right);                // 合并两个有序数组                Merge(arr, left, mid, right);            }        }        public static void Merge(int[] arr, int left, int mid, int right)        {            int n1 = mid - left + 1; // 左半部分数组的长度            int n2 = right - mid;    // 右半部分数组的长度            // 创建临时数组            int[] leftArr = new int[n1];            int[] rightArr = new int[n2];            // 将数据拷贝到临时数组            for (int i = 0; i < n1; ++i)            {                leftArr[i] = arr[left + i];            }            for (int j = 0; j < n2; ++j)            {                rightArr[j] = arr[mid + 1 + j];            }            // 合并两个有序数组            int k = left;   // 初始化合并后的数组索引            int p = 0;      // 初始化左半部分数组的索引            int q = 0;      // 初始化右半部分数组的索引            while (p < n1 && q < n2)            {                if (leftArr[p] <= rightArr[q])                {                    arr[k] = leftArr[p];                    p++;                }                else                {                    arr[k] = rightArr[q];                    q++;                }                k++;            }            // 复制左半部分数组的剩余元素            while (p < n1)            {                arr[k] = leftArr[p];                p++;                k++;            }            // 复制右半部分数组的剩余元素            while (q < n2)            {                arr[k] = rightArr[q];                q++;                k++;            }        }        public static void MergeSortRun()        {            int[] array = { 19, 27, 46, 48, 50, 2, 4, 44, 47, 36, 38, 15, 26, 5, 3 };            Console.WriteLine("排序前数组:" + string.Join(", ", array));            MergeSort(array, 0, array.Length - 1);            Console.WriteLine("排序后数组:" + string.Join(", ", array));        }

运行结果

图片图片BH128资讯网——每日最新资讯28at.com

总结

归并排序是一种高效稳定的排序算法,时间复杂度为O(nlogn)。它的核心思想是将待排序序列分割成更小的子序列,然后逐步合并并排序这些子序列,最终得到一个有序序列。归并排序需要额外的空间来存储临时数组,但由于其分治的特性,适用于对链表和外部存储的排序。BH128资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-12750-0.html聊聊C#归并排序算法

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Go 语言中 panic 和 recover 搭配使用

下一篇: 深入了解归并排序:原理、性能分析与 Java 实现

标签:
  • 热门焦点
  • 卢伟冰长文解析K60至尊版 对Redmi有着里程碑式的意义

    在今天的Redmi后性能时代战略发布会结束之后,Redmi总经理卢伟冰又带来了一篇长文,详解了为什么 Redmi 要开启后性能时代?为什么选择和 MediaTek、Pixelworks 深度合作?以及后性
  • Redmi Buds 4开箱简评:才199还有降噪 可以无脑入

    在上个月举办的Redmi Note11T Pro系列新机发布会上,除了两款手机新品之外,Redmi还带来了两款TWS真无线蓝牙耳机产品,Redmi Buds 4和Redmi Buds 4 Pro,此前我们在Redmi Note11T
  • 太卷!Redmi MAX 100英寸电视便宜了:12999元买Redmi史上最大屏

    8月5日消息,从小米商城了解到,Redmi MAX 100英寸巨屏电视日前迎来官方优惠,到手价12999元,比发布价便宜了7000元,在大屏电视市场开卷。据了解,Redmi MAX 100
  • 深度探索 Elasticsearch 8.X:function_score 参数解读与实战案例分析

    在 Elasticsearch 中,function_score 可以让我们在查询的同时对搜索结果进行自定义评分。function_score 提供了一系列的参数和函数让我们可以根据需求灵活地进行设置。近期
  • 中国家电海外掘金正当时|出海专题

    作者|吴南南编辑|胡展嘉运营|陈佳慧出品|零态LT(ID:LingTai_LT)2023年,出海市场战况空前,中国创业者在海外纷纷摩拳擦掌,以期能够把中国的商业模式、创业理念、战略打法输出海外,他们依
  • 大厂卷向扁平化

    来源:新熵作者丨南枝 编辑丨月见大厂职级不香了。俗话说,兵无常势,水无常形,互联网企业调整职级体系并不稀奇。7月13日,淘宝天猫集团启动了近年来最大的人力制度改革,目前已形成一
  • ESG的面子与里子

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之三伏大幕拉起,各地高温预警不绝,但处于厄尔尼诺大&ldquo;烤&rdquo;之下的除了众生,还有各大企业发布的ESG报告。ESG是&ldquo;环境保
  • 微博大门常打开,迎接海外画师漂洋东渡

    作者:互联网那些事&ldquo;起猛了,我能看得懂日语了&rdquo;。&ldquo;为什么日本人说话我能听懂?&rdquo;&ldquo;中文不像中文,日语不像日语,但是我竟然看懂了&rdquo;&hellip;&hell
  • iQOO Neo8 Pro真机谍照曝光:天玑9200+和V1+旗舰双芯加持

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
Top