C#排序算法之归并排序

 更新时间:2020年01月30日 09:56:13   作者:mlovelcottage  
这篇文章主要为大家详细介绍了C#排序算法之归并排序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C#实现归并排序具体代码,供大家参考,具体内容如下

代码:

//归并排序(目标数组,子表的起始位置,子表的终止位置)
  private static void MergeSortFunction(int[] array, int first, int last)
  {
   try
   {
    if (first < last) //子表的长度大于1,则进入下面的递归处理
    {
     int mid = (first + last) / 2; //子表划分的位置
     MergeSortFunction(array, first, mid); //对划分出来的左侧子表进行递归划分
     MergeSortFunction(array, mid + 1, last); //对划分出来的右侧子表进行递归划分
     MergeSortCore(array, first, mid, last); //对左右子表进行有序的整合(归并排序的核心部分)
    }
   }
   catch (Exception ex)
   { }
  }
 
  //归并排序的核心部分:将两个有序的左右子表(以mid区分),合并成一个有序的表
  private static void MergeSortCore(int[] array, int first, int mid, int last)
  {
   try
   {
    int indexA = first; //左侧子表的起始位置
    int indexB = mid + 1; //右侧子表的起始位置
    int[] temp = new int[last + 1]; //声明数组(暂存左右子表的所有有序数列):长度等于左右子表的长度之和。
    int tempIndex = 0;
    while (indexA <= mid && indexB <= last) //进行左右子表的遍历,如果其中有一个子表遍历完,则跳出循环
    {
     if (array[indexA] <= array[indexB]) //此时左子表的数 <= 右子表的数
     {
      temp[tempIndex++] = array[indexA++]; //将左子表的数放入暂存数组中,遍历左子表下标++
     }
     else//此时左子表的数 > 右子表的数
     {
      temp[tempIndex++] = array[indexB++]; //将右子表的数放入暂存数组中,遍历右子表下标++
     }
    }
    //有一侧子表遍历完后,跳出循环,将另外一侧子表剩下的数一次放入暂存数组中(有序)
    while (indexA <= mid)
    {
     temp[tempIndex++] = array[indexA++];
    }
    while (indexB <= last)
    {
     temp[tempIndex++] = array[indexB++];
    }
 
    //将暂存数组中有序的数列写入目标数组的制定位置,使进行归并的数组段有序
    tempIndex = 0;
    for (int i = first; i <= last; i++)
    {
     array[i] = temp[tempIndex++];
    }
   }
   catch (Exception ex)
   { }
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C#操作非持久化内存映射文件详解

    C#操作非持久化内存映射文件详解

    多个进程之间,通过操作未映射到磁盘上现有文件的内存映射文件,可以实现数据共享和类似进程间通讯的功能,下面我们就来学习一下C#如何操作非持久化内存映射文件的吧
    2023-12-12
  • C#使用windows服务发送邮件

    C#使用windows服务发送邮件

    这篇文章主要为大家详细介绍了C#使用windows服务发送邮件的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • WPF自定义控件的实现

    WPF自定义控件的实现

    本文主要介绍了WPF自定义控件的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • c#语言使用Unity粒子系统制作手雷爆炸

    c#语言使用Unity粒子系统制作手雷爆炸

    这篇文章主要为大家介绍了Unity的粒子系统由粒子发射器、粒子动画器、粒子渲染器组成,通过使用一或两个纹理多次绘制,创造一个混沌的效果,通过复习粒子系统做一个手雷和实弹投掷现场
    2022-04-04
  • C#生成随机验证码代码分享

    C#生成随机验证码代码分享

    这篇文章主要分享了C#生成随机验证码代码,另外附上使用示例,非常的简单实用,有需要的朋友可以参考下
    2014-10-10
  • 你是不是这样写异常处理代码的呢?

    你是不是这样写异常处理代码的呢?

    本篇文章是对,你是不是这样写异常处理代码的进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • Unity3D Shader实现扫描显示效果(2)

    Unity3D Shader实现扫描显示效果(2)

    这篇文章主要为大家详细介绍了Unity3D Shader实现扫描显示效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-03-03
  • C#实现将记事本中的代码编译成可执行文件的方法

    C#实现将记事本中的代码编译成可执行文件的方法

    这篇文章主要介绍了C#实现将记事本中的代码编译成可执行文件的方法,很实用的技巧,需要的朋友可以参考下
    2014-08-08
  • c#字符串去掉空格的二种方法(去掉两端空格)

    c#字符串去掉空格的二种方法(去掉两端空格)

    本文主要介绍了字符串去掉两端空格,并且将字符串中多个空格替换成一个空格的方法,需要的朋友可以参考下
    2014-02-02
  • C#中AS和IS关键字的用法

    C#中AS和IS关键字的用法

    这篇文章主要介绍了C#中AS和IS关键字的用法的相关资料,需要的朋友可以参考下
    2016-03-03

最新评论