欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C#堆排序实现方法

程序员文章站 2023-11-27 13:11:52
本文实例讲述了c#堆排序实现方法。分享给大家供大家参考。具体如下: private static void adjust (int[] list, int i,...

本文实例讲述了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#程序设计有所帮助。