首页 > 其他 > 详细

C# 内部的快速排序实现

时间:2014-05-26 21:34:14      阅读:321      评论:0      收藏:0      [点我收藏+]
bubuko.com,布布扣
 1 private void QuickSort(int[] map, int left, int right)
 2 {
 3     do
 4     {
 5         int index = left;
 6         int num2 = right;
 7         int num3 = map[index + ((num2 - index) >> 1)];
 8         do
 9         {
10             while ((index < map.Length) && (this.CompareKeys(num3, map[index]) > 0))
11             {
12                 index++;
13             }
14             while ((num2 >= 0) && (this.CompareKeys(num3, map[num2]) < 0))
15             {
16                 num2--;
17             }
18             if (index > num2)
19             {
20                 break;
21             }
22             if (index < num2)
23             {
24                 int num4 = map[index];
25                 map[index] = map[num2];
26                 map[num2] = num4;
27             }
28             index++;
29             num2--;
30         }
31         while (index <= num2);
32         if ((num2 - left) <= (right - index))
33         {
34             if (left < num2)
35             {
36                 this.QuickSort(map, left, num2);
37             }
38             left = index;
39         }
40         else
41         {
42             if (index < right)
43             {
44                 this.QuickSort(map, index, right);
45             }
46             right = num2;
47         }
48     }
49     while (left < right);
50 }
bubuko.com,布布扣

其中CompareKeys需要自己实现,也叫比较器,C#内部很多地方都要用到

 

C# 内部的快速排序实现,布布扣,bubuko.com

C# 内部的快速排序实现

原文:http://www.cnblogs.com/yayaxxww/p/3745867.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!