C#堆排序 C#堆排序实现方法

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

C#堆排序 C#堆排序实现方法

令狐不聪   2021-03-21 我要评论
想了解C#堆排序实现方法的相关内容吗,令狐不聪在本文为您仔细讲解C#堆排序的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:C#,堆排序,下面大家一起来学习吧。

本文实例讲述了C#堆排序实现方法。分享给大家供大家参考。具体如下:

private static void Adjust (int[] list, int i, int m)
{
 int Temp = list[i];
 int j = i * 2 + 1;
 while (j <= m)
 {
  //more children
  if(j < m)
   if(list[j] < list[j + 1])
    j = j + 1;
  //compare roots and the older children
  if(Temp < list[j])
  {
   list[i] = list[j];
   i = j;
   j = 2 * i + 1;
  }
  else
  {
   j = m + 1;
  }
 }
 list [i] = Temp;
}
public static void HeapSort (int[] list)
{
 //build the initial heap
 for (int i = (list.Length - 1) / 2; i > = 0; i-)
  Adjust (list, i, list.Length - 1);
 
 //swap root node and the last heap node
 for (int i = list.Length - 1; i > = 1; i-)
 {
  int Temp = list [0];
  list [0] = list [i];
  list [i] = Temp;
  Adjust (list, 0, i - 1);
 }
}

希望本文所述对大家的C#程序设计有所帮助。

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们