手机
当前位置:查字典教程网 >编程开发 >C#教程 >C#堆排序实现方法
C#堆排序实现方法
摘要:本文实例讲述了C#堆排序实现方法。分享给大家供大家参考。具体如下:privatestaticvoidAdjust(int[]list,int...

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

【C#堆排序实现方法】相关文章:

共享锁using范围的实现方法

C#图片压缩的实现方法

c#二进制逆序方法详解

C++堆排序算法的实现方法

C# 透明窗体制作实现方法比较分析

C#归并排序的实现方法(递归,非递归,自然归并)

C#中Web.Config加密与解密的方法

C# 抓取网页内容的方法

c#解压文件的实例方法

WinForm子窗体访问父窗体控件的实现方法

精品推荐
分类导航