C# 排序算法之归并排序

2024-09-07 10:04

本文主要是介绍C# 排序算法之归并排序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

归并排序(Merge Sort)是一种分而治之的排序算法。它将一个数组分成两半,对每半部分递归地应用归并排序,然后将排序好的两部分合并成一个有序的数组。归并排序的关键在于合并两个已排序的数组(或数组段)。

以下是归并排序算法的C#实现:

using System;class Program
{static void Main(string[] args){int[] arr = { 12, 11, 13, 5, 6, 7 };MergeSort(arr, 0, arr.Length - 1);Console.WriteLine("Sorted array: ");PrintArray(arr);}// 归并排序方法static void MergeSort(int[] arr, int left, int right){if (left < right){// 找到中间索引int middle = left + (right - left) / 2;// 对左半部分进行归并排序MergeSort(arr, left, middle);// 对右半部分进行归并排序MergeSort(arr, middle + 1, right);// 合并两个已排序的部分Merge(arr, left, middle, right);}}// 合并两个已排序的部分static void Merge(int[] arr, int left, int middle, int right){// 创建一个临时数组来存储合并后的数据int[] temp = new int[right - left + 1];// 初始化左右子数组的指针int i = left;    // 左子数组的起始索引int j = middle + 1; // 右子数组的起始索引int k = 0;    // 临时数组的索引// 合并两个子数组到temp[]while (i <= middle && j <= right){if (arr[i] <= arr[j]){temp[k++] = arr[i++];}else{temp[k++] = arr[j++];}}// 复制左子数组中剩余的元素(如果有的话)while (i <= middle){temp[k++] = arr[i++];}// 复制右子数组中剩余的元素(如果有的话)while (j <= right){temp[k++] = arr[j++];}// 将合并后的数据复制回原数组for (i = left, k = 0; i <= right; i++, k++){arr[i] = temp[k];}}// 打印数组的方法static void PrintArray(int[] arr){foreach (int i in arr){Console.Write(i + " ");}Console.WriteLine();}
}

在这个实现中,MergeSort 方法是归并排序的递归实现。它接受一个数组和两个整数作为参数,分别表示要排序的数组段落的起始和结束索引。如果起始索引小于结束索引,说明数组段落中有多个元素,需要进行排序。方法首先找到中间索引,然后对左半部分和右半部分递归地调用 MergeSort 方法进行排序。最后,调用 Merge 方法将两个已排序的部分合并成一个有序的数组。

Merge 方法实现了合并两个已排序的部分的功能。它首先创建一个临时数组来存储合并后的数据,并使用三个指针(或索引)来遍历和合并两个子数组。当两个子数组都遍历完毕后,如果有剩余的元素,则将它们复制到临时数组的末尾。最后,将合并后的数据复制回原数组。

PrintArray 方法与之前一样,用于打印排序后的数组。

归并排序的时间复杂度为O(n log n),是一种稳定的排序算法,并且它适用于大规模数据集。然而,由于归并排序涉及到递归调用和大量数据的复制操作,因此在某些情况下,它可能会比其他排序算法(如快速排序)消耗更多的内存和时间。

这篇关于C# 排序算法之归并排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1144758

相关文章

C#高效实现Word文档内容查找与替换的6种方法

《C#高效实现Word文档内容查找与替换的6种方法》在日常文档处理工作中,尤其是面对大型Word文档时,手动查找、替换文本往往既耗时又容易出错,本文整理了C#查找与替换Word内容的6种方法,大家可以... 目录环境准备方法一:查找文本并替换为新文本方法二:使用正则表达式查找并替换文本方法三:将文本替换为图

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点

C#中SortedSet的具体使用

《C#中SortedSet的具体使用》SortedSet是.NETFramework4.0引入的一个泛型集合类,它实现了一个自动排序的集合,内部使用红黑树数据结构来维护元素的有序性,下面就来介绍一下如... 目录基础概念主要特性创建和初始化基本创建方式自定义比较器基本操作添加和删除元素查询操作范围查询集合运

C# Opacity 不透明度的具体使用

《C#Opacity不透明度的具体使用》本文主要介绍了C#Opacity不透明度的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录WinFormsOpacity以下是一些使用Opacity属性的示例:设置窗体的透明度:设置按钮的透

C#控制台程序同步调用WebApi实现方式

《C#控制台程序同步调用WebApi实现方式》控制台程序作为Job时,需同步调用WebApi以确保获取返回结果后执行后续操作,否则会引发TaskCanceledException异常,同步处理可避免异... 目录同步调用WebApi方法Cls001类里面的写法总结控制台程序一般当作Job使用,有时候需要控制

在ASP.NET项目中如何使用C#生成二维码

《在ASP.NET项目中如何使用C#生成二维码》二维码(QRCode)已广泛应用于网址分享,支付链接等场景,本文将以ASP.NET为示例,演示如何实现输入文本/URL,生成二维码,在线显示与下载的完整... 目录创建前端页面(Index.cshtml)后端二维码生成逻辑(Index.cshtml.cs)总结

C#异步编程ConfigureAwait的使用小结

《C#异步编程ConfigureAwait的使用小结》本文介绍了异步编程在GUI和服务器端应用的优势,详细的介绍了async和await的关键作用,通过实例解析了在UI线程正确使用await.Conf... 异步编程是并发的一种形式,它有两大好处:对于面向终端用户的GUI程序,提高了响应能力对于服务器端应

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

C#中的Drawing 类案例详解

《C#中的Drawing类案例详解》文章解析WPF与WinForms的Drawing类差异,涵盖命名空间、继承链、常用类及应用场景,通过案例展示如何创建带阴影圆角矩形按钮,强调WPF的轻量、可动画特... 目录一、Drawing 是什么?二、典型用法三、案例:画一个“带阴影的圆角矩形按钮”四、WinForm