A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© sunrise2 高级黑马   /  2014-7-23 23:23  /  714 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 sunrise2 于 2014-7-23 23:33 编辑

   堆排序
堆排序适合于数据量非常大的场合(百万数据)。
堆排序不需要大量的递归或者多维的暂存数组。
这对于数据量非常巨大的序列是合适的。
比如超过数百万条记录,因为快速排序,归并排序都使用递归来设计算法,
在数据量非常大的时候,可能会发生堆栈溢出错误。
堆排序会将所有的数据建成一个堆,最大的数据在堆顶,
然后将堆顶数据和序列的最后一个数据交换。
接下来再次重建堆,交换数据,依次下去,就可以排序所有的数据。
  1. /// <summary>
  2.     /// 堆排序
  3.     /// </summary>
  4.     public class HeapSort : ISort
  5.     {
  6.         public int[] Sort(int[] array)
  7.         {
  8.             if (array != null)
  9.             {
  10.                 HeapHanle(array, array.Length);//整理了堆结构
  11.                 for (int i = array.Length - 1; i >= 0; i--)
  12.                 {
  13.                     Swap(ref array[0], ref array[i]);
  14.                     if (i > 1)
  15.                     {
  16.                         HeapToDown(array, 0, i);
  17.                     }
  18.                 }
  19.             }
  20.             return array;
  21.         }
  22.         /// <summary>
  23.         /// 整理堆结构
  24.         /// </summary>
  25.         /// <param name="array"></param>
  26.         /// <param name="length"></param>
  27.         private static void HeapHanle(int[] array, int length)
  28.         {
  29.             for (int i = length / 2 - 1; i >= 0; i--)
  30.             {
  31.                 HeapToDown(array, i, length);
  32.             }
  33.         }
  34.         /// <summary>
  35.         /// 从下往上处理
  36.         /// </summary>
  37.         /// <param name="array">数组</param>
  38.         /// <param name="i">给定的节点数组索引</param>
  39.         private static void HeapToUp(int[] array, int i)
  40.         {
  41.             int cur = array[i];
  42.             int preIndex = (i - 1) / 2;
  43.             while (i > 0 && preIndex >= 0 && cur < array[preIndex])
  44.             {
  45.                 array[preIndex] = cur;
  46.                 i = preIndex;
  47.                 preIndex = (i - 1) / 2;
  48.             }
  49.             array[i] = cur;
  50.         }
  51.         /// <summary>
  52.         /// 从上往下处理
  53.         /// </summary>
  54.         /// <param name="array">数组</param>
  55.         /// <param name="i">给定的节点数组索引</param>
  56.         private static void HeapToDown(int[] array, int i, int length)
  57.         {
  58.             int cur = array[i];
  59.             int nextIndex = 2 * i + 1;//左孩子对应的数组索引
  60.             while (nextIndex < length)
  61.             {
  62.                 if (nextIndex + 1 < length)
  63.                 {
  64.                     if (array[nextIndex] > array[nextIndex + 1])
  65.                     {
  66.                         nextIndex = nextIndex + 1;//右孩子
  67.                     }
  68.                 }

  69.                 if (cur <= array[nextIndex])
  70.                 {
  71.                     break;
  72.                 }
  73.                 else//处理
  74.                 {
  75.                     array[i] = array[nextIndex];
  76.                     i = nextIndex;
  77.                     nextIndex = 2 * i + 1;
  78.                 }
  79.             }
  80.             array[i] = cur;
  81.         }

  82.         public static void Swap(ref int int1, ref int int2)
  83.         {
  84.             int temp = int1;
  85.             int1 = int2;
  86.             int2 = temp;
  87.         }
  88.     }
复制代码
测试代码:
  1. class Program
  2.     {
  3.         public static Random re = new Random();
  4.         static void Main(string[] args)
  5.         {
  6.             Stopwatch stw4 = new Stopwatch();
  7.             Stopwatch stw5 = new Stopwatch();
  8.             Stopwatch stw6 = new Stopwatch();

  9.             int[] intArray4 = GetArray(int.MaxValue / 100000);
  10.             int[] intArray5 = GetArray(int.MaxValue / 100000);
  11.             int[] intArray6 = GetArray(int.MaxValue / 100000);

  12.             ISort sort4 = new HeapSort();//堆排序
  13.             stw4.Start();
  14.             int[] result4 = sort4.Sort(intArray4);
  15.             stw4.Stop();
  16.             Console.WriteLine("输出排序的结果(堆排序)");
  17.             Console.WriteLine("程序共运行时间:" + stw4.Elapsed.ToString());

  18.             ISort sort5 = new MergeSort();//归并排序
  19.             stw5.Start();
  20.             int[] result5 = sort5.Sort(intArray5);
  21.             stw5.Stop();
  22.             Console.WriteLine("输出排序的结果(归并排序)");
  23.             Console.WriteLine("程序共运行时间:" + stw5.Elapsed.ToString());

  24.             ISort sort6 = new QuickSort();//快速排序
  25.             stw6.Start();
  26.             int[] result6 = sort6.Sort(intArray6);
  27.             stw6.Stop();
  28.             Console.WriteLine("输出排序的结果(快速排序)");
  29.             Console.WriteLine("程序共运行时间:" + stw6.Elapsed.ToString());

  30.             Console.ReadKey();
  31.         }

  32.         private static int[] GetArray(long _arrayLength)
  33.         {
  34.             long arrayLength = _arrayLength;

  35.             //初始化数组
  36.             int[] intArray = new int[arrayLength];

  37.             for (int i = 0; i < arrayLength; i++)
  38.             {
  39.                 intArray[i] = re.Next();
  40.             }
  41.             return intArray;
  42.         }
  43.     }
复制代码

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马