首页 > 编程语言 >C#:快速排序

C#:快速排序

时间:2022-10-02 19:55:05浏览次数:97  
标签:C# 值为 int low 数组 array 排序 快速

1. 介绍

快速排序是一种非常高效的排序算法,它采用“分而治之”的思想,把大的拆分为小的,小的再拆分为更小的。

其原理如下:
对于一组给定的记录,通过一趟排序后,将原序列分为两部分,其中前一部分的所有记录均比后一部分的所有记录小,然后再依次对前后两部分的记录进行快速排序,递归该过程,直到序列中的所有记录均有序为止。

具体而言,算法步骤如下:

  1. 分解:将输入的序列array[m..n]划分成两个非空子序列array [m…k]和array [k+1…n],使array [m…k]中任一元素的值不大于array [k+1…n]中任一元素的值。
  2. 递归求解:通过递归调用快速排序算法分别对array [m…k]和array [k+1…n]进行排序。
  3. 合并:由于对分解出的两个子序列的排序是就地进行的,所以在array [m…k]和array [k+1…n]都排好序后不需要执行任何计算array [m…n]就已排好序。

2. 排序过程

以数组{ 5, 4, 9, 8, 7, 6, 0, 1, 3, 2 }为例。排序过程如下:

  • 取第一个值为基准值,即5。
  • i为下标,从左向右移。
  • j为下标,从右向左移。
5 4 9 8 7 6 0 1 3 2
i j

从j开始,j数组值为2,<5,所以应该放到左边,赋值给当前i的值,i右移一位。

2 4 9 8 7 6 0 1 3 2
i j

i数组值为4,<5,所以位置不变,i再右移一位。

2 4 9 8 7 6 0 1 3 2
i j

i数组值为9,>5,所以应该放到右边,赋值给当前j的值,j向左移一位。

2 4 9 8 7 6 0 1 3 9
i j

j数组值为3,<5,所以应该放到左边,赋值给当前i的值,i向右移一位。

2 4 3 8 7 6 0 1 3 9
i j

i数组值为8,>5,所以放到右边,赋值个当前j的值,j向左移一位。

2 4 3 8 7 6 0 1 8 9
i j

j数组值为1,<5,所以放到左边,赋值给当前i的值,i右移。

2 4 3 1 7 6 0 1 8 9
i j

i数组值为7,>5,放右边,j左移。

2 4 3 1 7 6 0 7 8 9
i j

j数组值为0,<5,放左边,i右移。

2 4 3 1 0 6 0 7 8 9
i j

i数组值为6,>5,放右边,j左移。

2 4 3 1 0 6 6 7 8 9
i,j

这时,i和j已经相等,跳出移动循环,把基准值赋给i数组值。

2 4 3 1 0 5 6 7 8 9

第一趟排序之后,数组就为{ 2, 4, 3, 1, 0, 5, 6, 7,8,9 }。
第二趟排序的话就会分成两组,即{2,4,3,1,0}和{5,6,7,8,9 },继续这样排,直到不能排为止。

3. 程序代码

程序如下:

static void Main(string[] args)
{
    int i = 0;
    int[] a = { 5, 4, 9, 8, 7, 6, 0, 1, 3, 2 };
    int len = a.Length;
    quickSort(a);
    for (i = 0; i < len; i++)
    {
        Console.WriteLine(a[i] + "");
    }
}
public static void quickSort(int[] array)
{
    sort(array, 0, array.Length - 1);
}
/// <summary>
/// 排序
/// </summary>
/// <param name="array">需要排列的数组</param>
/// <param name="low">低位</param>
/// <param name="high">高位</param>
static void sort(int[] array, int low, int high)
{
    if (low >= high)
    {
        return;
    }
    // 基准值 选取当前数组第一个值
    int index = array[low];
    // 低位i从左向右扫描
    int i = low;
    // 高位j从由向左扫描
    int j = high;
    while (i < j)
    {
        while (i < j && array[j] >= index)
        {
            j--;
        }
        if (i < j)
        {
            array[i] = array[j];
            i++;
        }
        while (i < j && array[i] < index)
        {
            i++;
        }
        if (i < j)
        {
            array[j] = array[i];
            j--;
        }
    }
    array[i] = index;
    // 左边的继续递归排序
    sort(array, low, i - 1);
    // 右边的继续递归排序
    sort(array, i + 1, high);
}

标签:C#,值为,int,low,数组,array,排序,快速
From: https://www.cnblogs.com/nullcodeworld/p/16749326.html

相关文章

  • CSharp: Visitor Pattern
     ///<summary>///SummarydescriptionforEmployee.///VisitorPattern访问者模式///20220918///geovindu,GeovinDu,涂聚文///</......
  • docker 精简版容器 没有vim和vi怎么编辑文件
    docker编辑文件精简版没有vi也没有vim,那么要怎么编辑文件?echoabc>>test.txt下载vim在宿主机编写好文件之后copy到容器中使用sed命令Linuxsed命令|菜鸟教程......
  • docker常用命令
    docker常用命令查看镜像dockerimagels查看运行中的容器dockerps宿主机和容器间复制文件从主机复制到容器sudodockercphost_pathcontainerID:container_......
  • 无需内嵌代码的全新GUI截图方案在TouchGFX,ThreadX GUIX,emWin,LVGL,AWTK全部测试通过,含多
    搞GUI这么多年来,这个问题一直是个心病,通过这段时间的研究,终于有个产品样子了。早期包括现在做产品效果展示,需要截屏时,很多时候依然采用的SD卡/U盘这种的古老方案,不仅麻烦,......
  • springboot+vue前后端分离项目CRUD
    今天完成了项目最基础的一个表的增删改查,后端是springboot+Myabtis-Plus框架,没有写SQL。主要学习一下springboot+vue项目的搭建和使用,以及用elementUI搭建的页面。并......
  • oracle数据库运行内存PGA+SGA分配
    调整内存大小用dba身份进入oracle,(sqlplussys/密码assysdba):--显示内存分配情况showparametersga;--修改占用内存的大小altersystemsetsga_max_size=200mscop......
  • 使用IDEA进行javaDoc时报错:javadoc: 错误 - 无效的标记: --source-path
    可能是因为idea版本太高其javadoc生成工具不能使用java8版本了,亦或是需要做一些设置 idea生成javadoc文件使用java8版本时报错  在这里修改一下java版本 我......
  • 数据分析(1) --在MATLAB中通过Nvidia GeForce GPU加速深度学习计算
    0.前言笔者用的是华硕飞行堡垒电脑,自带2G的GPU1.基本环境软件:MATLAB2020a (当前最新的matlab版本,提供了很多关于深度学习(常见的卷积神经网络和循环神经网络)的接口)据说ma......
  • IfcEnergyMeasure
    IfcEnergyMeasure类型定义IfcEnergyMeasure是对所需或使用能量的度量。通常以焦耳(J,Nm)计量。类型:REALIFC2.0中的新类型。 EXPRESSSpecificationTYPEIfcEnergyMe......
  • docker 没用镜像造成磁盘满问题
    查看磁盘的使用状态df-a从上图可以看到,主要是dockeroverlay2和dev/vda1下面的文件使用率过爆,对应的文件也可以看到。首先,排查dockeroverlay2下面的文件查看docker的......