博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

奇偶排序

Posted on 2009-12-19 17:29  smallnest  阅读(228)  评论(0编辑  收藏  举报

 

1 using System;
2  using System.Collections.Generic;
3
4
5  namespace Com.Colobu.Algorithm.Exchange
6 {
7 /// <summary>
8 /// <b>奇偶排序</b>的思路是在数组中重复两趟扫描。
9 /// 第一趟扫描选择所有的数据项对,a[j]和a[j+1],j是奇数(j=1, 3, 5……)。
10 /// 如果它们的关键字的值次序颠倒,就交换它们。
11 /// 第二趟扫描对所有的偶数数据项进行同样的操作(j=2, 4,6……)。
12 /// 重复进行这样两趟的排序直到数组全部有序。
13 ///
14 /// 平均时间复杂度:O(n^2)
15 /// Stability:Yes
16 /// </summary>
17 public class OddEvenSortAlgorithm
18 {
19 public static void OddEvenSort<T>(IList<T> szArray) where T : IComparable
20 {
21 bool sorted = false;
22 while (!sorted)
23 {
24 sorted = true;
25 // odd-even
26 for (int i = 1; i < szArray.Count - 1; i += 2)
27 {
28 if (szArray[i].CompareTo(szArray[i + 1]) > 0)
29 {
30 Swap(szArray, i, i + 1);
31 sorted = false;
32 }
33 }
34 // even-odd
35 for (int j = 0; j < szArray.Count - 1; j += 2)
36 {
37 if (szArray[j].CompareTo(szArray[j + 1]) > 0)
38 {
39 Swap(szArray, j, j + 1);
40 sorted = false;
41 }
42 }
43 }
44 }
45 private static void Swap<T>(IList<T> szArray, int i, int j)
46 {
47 T tmp = szArray[i];
48 szArray[i] = szArray[j];
49 szArray[j] = tmp;
50 }
51 }
52 }
53

 

类别:排序-交换排序
参看 维基百科的定义