百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

C#实现归并排序与快速排序

liuian 2025-08-01 18:41 72 浏览

字数 914,阅读大约需 5 分钟

C#实现归并排序与快速排序

以下是使用 C# 实现的归并排序和快速排序算法代码:

using System;
using System.Collections.Generic;

publicclassSortingAlgorithms
{
// 归并排序入口方法
public static void MergeSort<T>(T[] arr) where T : IComparable<T>
{
if (arr == || arr.Length <= 1)
return;

MergeSort(arr, 0, arr.Length - 1);
}

// 归并排序递归实现
private static void MergeSort<T>(T[] arr, int left, int right) where T : IComparable<T>
{
if (left < right)
{
int mid = left + (right - left) / 2;
MergeSort(arr, left, mid); // 排序左半部分
MergeSort(arr, mid + 1, right); // 排序右半部分
Merge(arr, left, mid, right); // 合并两个有序数组
}
}

// 合并两个有序子数组
private static void Merge<T>(T[] arr, int left, int mid, int right) where T : IComparable<T>
{
int n1 = mid - left + 1;
int n2 = right - mid;

// 创建临时数组
T[] L = new T[n1];
T[] R = new T[n2];

// 拷贝数据到临时数组
Array.Copy(arr, left, L, 0, n1);
Array.Copy(arr, mid + 1, R, 0, n2);

// 合并临时数组
int i = 0, j = 0, k = left;
while (i < n1 && j < n2)
{
if (L[i].CompareTo(R[j]) <= 0)
{
arr[k] = L[i];
i++;
}
else
{
arr[k] = R[j];
j++;
}
k++;
}

// 拷贝剩余元素
while (i < n1)
{
arr[k] = L[i];
i++;
k++;
}

while (j < n2)
{
arr[k] = R[j];
j++;
k++;
}
}

// 快速排序入口方法
public static void QuickSort<T>(T[] arr) where T : IComparable<T>
{
if (arr == || arr.Length <= 1)
return;

QuickSort(arr, 0, arr.Length - 1);
}

// 快速排序递归实现
private static void QuickSort<T>(T[] arr, int low, int high) where T : IComparable<T>
{
if (low < high)
{
int pi = Partition(arr, low, high); // 获取分区点
QuickSort(arr, low, pi - 1); // 排序左分区
QuickSort(arr, pi + 1, high); // 排序右分区
}
}

// Lomuto分区方案
private static int Partition<T>(T[] arr, int low, int high) where T : IComparable<T>
{
T pivot = arr[high]; // 选择最后一个元素作为基准
int i = low - 1; // 较小元素的分界点

for (int j = low; j < high; j++)
{
if (arr[j].CompareTo(pivot) < 0)
{
i++;
Swap(arr, i, j); // 交换元素
}
}

Swap(arr, i + 1, high); // 将基准放到正确位置
return i + 1; // 返回基准索引
}

// 交换数组元素
private static void Swap<T>(T[] arr, int i, int j)
{
T temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}

// 测试代码
public static void Main()
{
int[] numbers = { 12, 11, 13, 5, 6, 7 };

Console.WriteLine("Original array:");
PrintArray(numbers);

// 测试归并排序
MergeSort(numbers);
Console.WriteLine("\nSorted with MergeSort:");
PrintArray(numbers);

int[] numbers2 = { 10, 7, 8, 9, 1, 5 };
Console.WriteLine("\nNew array for QuickSort:");
PrintArray(numbers2);

// 测试快速排序
QuickSort(numbers2);
Console.WriteLine("\nSorted with QuickSort:");
PrintArray(numbers2);
}

// 辅助方法:打印数组
private static void PrintArray<T>(T[] arr)
{
foreach (T item in arr)
{
Console.Write(item + " ");
}
Console.WriteLine();
}
}

算法说明:

归并排序(Merge Sort)

  1. 1. 分治策略
  • o 将数组分成两半
  • o 递归排序左右子数组
  • o 合并两个有序子数组
  • 2. 时间复杂度
    • o 最优/平均/最差:O(n log n)
    • o 空间复杂度:O(n)(需要临时数组)
  • 3. 特点
    • o 稳定排序
    • o 适合链表排序
    • o 需要额外空间

    快速排序(Quick Sort)

    1. 1. 分治策略
    • o 选择基准元素(pivot)
    • o 分区:将小于基准的放在左侧,大于基准的放在右侧
    • o 递归排序左右分区
  • 2. 时间复杂度
    • o 最优/平均:O(n log n)
    • o 最差:O(n^2)(当数组已排序时)
    • o 空间复杂度:O(log n)(递归栈)
  • 3. 特点
    • o 不稳定排序
    • o 通常比归并排序快(常数因子更小)
    • o 原地排序(不需要额外空间)

    测试输出:

    Original array:
    12 11 13 5 6 7

    Sorted with MergeSort:
    5 6 7 11 12 13

    New array for QuickSort:
    10 7 8 9 1 5

    Sorted with QuickSort:
    1 5 7 8 9 10

    这两个实现都使用了泛型,支持任何实现了 IComparable<T> 接口的数据类型,并通过 Lomuto 分区方案实现了快速排序。


    相关推荐

    gho文件安装win10系统方法(gho文件怎么重装系统)

    不建议这么操作,如果真的要复制,也是很麻烦的,首先要删除win10里面所有的驱动,注意是所有的,然后关机,注意不能重启进入系统,否则又要重新再来,其次找个U盘pe启动盘或者启动光盘,在开机进入pe系统...

    下载163免费邮箱(免费下载网易邮箱163)

    第一步:首先,我们手机里要有一个浏览器,小编比较用UC浏览器,当然可以用手机都是自带网页浏览器的,我这边的手机下载网易邮箱第二步:打开UC浏览器或者带浏览器,我们在地址栏上直接输入最新网易邮箱下载安装...

    windows microsoft(windows microsoft store加载不出)

    电脑开机时出现MicrosoftWindows遇到意外错误,可以尝试用最后一次正确配置来恢复一下。1、重启电脑。2、在电脑显示完硬件信息之后,进入windows界面之前,按F8键。3、在出现的选项菜单...

    不读u盘的解决办法(不读u盘怎么回事)

    u盘在电脑里读不出来,出现这种情况,可以用以下方法解决:1、判断U盘是否已经正确插入USB接口,你可以拔下来换个插口试试。2、如果已经启用了USB设备但运行不正常,解决办法为在设备管理器中删除“通用...

    win11怎么激活(win11怎么激活office)

    目前,Windows11的永久激活方法还没有被公开或者确认。不过,你可以尝试以下几种方法来激活Windows11:使用数字许可证:如果你的电脑已经安装了Windows10并且已经激活,那么你可以...

    笔记本电脑快捷键大全(笔记本电脑快捷键大全常用)
    • 笔记本电脑快捷键大全(笔记本电脑快捷键大全常用)
    • 笔记本电脑快捷键大全(笔记本电脑快捷键大全常用)
    • 笔记本电脑快捷键大全(笔记本电脑快捷键大全常用)
    • 笔记本电脑快捷键大全(笔记本电脑快捷键大全常用)
    苹果恢复出厂设置(苹果恢复出厂设置还能恢复数据吗)

    首先打开手机上面的“设置”功能,进入手机的系统设置。进入手机的设置后,选择“通用"。进入通用之后,往下滑动页面,在页面的最下方可以看到“还原”的选项,点击进入。进入还原之后,有多个还原选项,我...

    路由器的配置步骤(路由器配置教学)

    打开浏览器-输入192.168.1.1(一般路由器地址是这个或者查看路由器背面的登录信息)进路由-输入用户名,密码,(默认一般是admin)。2、在【设置向导】里,选择【PPOE拨号】(有些是ADS...

    psp模拟器ios(psp模拟器ios推荐)

    psp手机模拟器推荐PPSSPP,作为最流行的开源PSP模拟器,因为其强大的功能和兼容性广受玩家们喜爱。虽然提供了PC和安卓双平台的支持,但是有碍于安卓设备的硬件,移动端PPSSPP的功能并不完整。不...

    台式机重装系统按f几(重装电脑系统按f几)

    F8、F9、F10、F11、F12、F2、del。一般用到这几个。下面以联想电脑装WIN10系统为例:1、将制作好的U盘插入要重装系统的电脑,开机画面出现电脑品牌logo时,不停地按“f2键”进入“B...

    win10激活错误代码0x8007007b

    Win10激活出现0x8007007b解决方法如下1、找到计算机,右键点击属性,确认你的电脑系统是否是windows10。2、鼠标右击桌面,依次点击个性化-主题-桌面图标设置,勾选计算机后依次点击应用...

    4000台式电脑最好的组装配置
    4000台式电脑最好的组装配置

    四千元价格组装电脑主机与五千元组装电脑主机的价格类似,因为电脑主机就几个大部件,电脑主机主板是多少代的产品?主板内存的插槽数?电脑处理器等如果是自己组装,都可以配置到十二代产品,电脑硬盘可以分为256G固态硬盘做系统盘,1T机械硬盘作为工作...

    2025-11-06 20:05 liuian

    linux是一种什么系统(linux属于什么系统)

    Linux,全称GNU/Linux,是一种免费使用和自由传播的类UNIX操作系统,是一个基于POSIX的多用户、多任务、支持多线程和多CPU的操作系统。其内核由林纳斯·本纳第克特·托瓦兹于1991年1...

    手机管理大师免费版(手机管理大师极速版)

    使用手机“文件管理”打开文件夹时提示访问受限,需要前往“文件”应用查看1.进入手机设置——安全——应用权限——权限/应用2.在手机桌面找到手机管家——权限隐私——应用权限——权限/应用?当然,相对于被...

    电脑能开机但是进不去桌面怎么办

    打开任务管理器按Ctrl+Shift+Esc打开任务管理器。文件中运行新任务点击文件,运行新任务。输入指令重启桌面输入explorer.exe,点击确定,等待桌面重启完成就可以了。电脑已经是我们生活中...