根据《算法设计与分析基础》中对归并排序的描述,写了一分C#代码实现。
具体的实现代码如下:
1
using
System;
2
using
System.Collections.Generic;
3
using
System.Text;
4![](/Images/OutliningIndicators/None.gif)
5
namespace
MergeSort
6
{
7
class Program
8
{
9
static void Main(string[] args)
10
{
11
Program p = new Program();
12![](/Images/OutliningIndicators/InBlock.gif)
13
int[] a = new int[] { 4, 2, 1, 6, 3, 6, 0, -5, 1, 1 };
14![](/Images/OutliningIndicators/InBlock.gif)
15
p.Sort(a);
16![](/Images/OutliningIndicators/InBlock.gif)
17
for (int i = 0; i < a.Length; i++)
18
{
19
System.Console.WriteLine(a[i]);
20
}
21
}
22![](/Images/OutliningIndicators/InBlock.gif)
23
/// <summary>
24
/// 利用归并排序按由下到大的顺序排序
25
/// </summary>
26
/// <param name="toBeSort"></param>
27
/// <returns></returns>
28
public int[] Sort(int[] toBeSort)
29
{
30
if (toBeSort.Length == 0)
31
{
32
throw new Exception("Sort array Error!");
33
}
34![](/Images/OutliningIndicators/InBlock.gif)
35
if (toBeSort.Length > 1)
36
{
37
int[] part1 = Sort(get1Part(toBeSort));
38
int[] part2 = Sort(get2Part(toBeSort));
39![](/Images/OutliningIndicators/InBlock.gif)
40
merger(part1, part2, toBeSort);
41
}
42![](/Images/OutliningIndicators/InBlock.gif)
43
return toBeSort;
44
}
45![](/Images/OutliningIndicators/InBlock.gif)
46
/// <summary>
47
/// 将part1和part2按照由小到大的顺序归并到数组toBeSort中
48
/// </summary>
49
/// <param name="part1"></param>
50
/// <param name="part2"></param>
51
/// <param name="toBeSort"></param>
52
private void merger(int[] part1, int[] part2, int[] toBeSort)
53
{
54
int index = 0;
55
int i1 = 0;
56
int i2 = 0;
57![](/Images/OutliningIndicators/InBlock.gif)
58
while (i1 < part1.Length && i2 < part2.Length)
59
{
60
if (part1[i1] < part2[i2])
61
{
62
toBeSort[index] = part1[i1];
63
i1++;
64
}
65
else
66
{
67
toBeSort[index] = part2[i2];
68
i2++;
69
}
70![](/Images/OutliningIndicators/InBlock.gif)
71
index++;
72
}
73![](/Images/OutliningIndicators/InBlock.gif)
74
while (i1 < part1.Length)
75
{
76
toBeSort[index] = part1[i1];
77
index++;
78
i1++;
79
}
80![](/Images/OutliningIndicators/InBlock.gif)
81
while (i2 < part2.Length)
82
{
83
toBeSort[index] = part2[i2];
84
index++;
85
i2++;
86
}
87
}
88![](/Images/OutliningIndicators/InBlock.gif)
89
/// <summary>
90
/// Get the second part of the array.
91
/// </summary>
92
/// <param name="toBeSort">The array to be sort.</param>
93
/// <returns>The second part of the array.</returns>
94
private int[] get2Part(int[] toBeSort)
95
{
96
int len = toBeSort.Length - toBeSort.Length / 2;
97
int[] part2 = new int[len];
98![](/Images/OutliningIndicators/InBlock.gif)
99
Array.Copy(toBeSort, toBeSort.Length / 2, part2, 0, len);
100![](/Images/OutliningIndicators/InBlock.gif)
101
return part2;
102
}
103![](/Images/OutliningIndicators/InBlock.gif)
104
/// <summary>
105
/// Get the first part of the array.
106
/// </summary>
107
/// <param name="toBeSort">The array to be sort.</param>
108
/// <returns>The first part of the array.</returns>
109
private int[] get1Part(int[] toBeSort)
110
{
111
int len = toBeSort.Length / 2;
112
int[] part1 = new int[len];
113
114
Array.Copy(toBeSort, part1, len);
115![](/Images/OutliningIndicators/InBlock.gif)
116
return part1;
117
}
118
}
119
}
120
![](/Images/OutliningIndicators/None.gif)
2
![](/Images/OutliningIndicators/None.gif)
3
![](/Images/OutliningIndicators/None.gif)
4
![](/Images/OutliningIndicators/None.gif)
5
![](/Images/OutliningIndicators/None.gif)
6
![](/Images/OutliningIndicators/ExpandedBlockStart.gif)
7
![](/Images/OutliningIndicators/InBlock.gif)
8
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
9
![](/Images/OutliningIndicators/InBlock.gif)
10
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
11
![](/Images/OutliningIndicators/InBlock.gif)
12
![](/Images/OutliningIndicators/InBlock.gif)
13
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
14
![](/Images/OutliningIndicators/InBlock.gif)
15
![](/Images/OutliningIndicators/InBlock.gif)
16
![](/Images/OutliningIndicators/InBlock.gif)
17
![](/Images/OutliningIndicators/InBlock.gif)
18
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
19
![](/Images/OutliningIndicators/InBlock.gif)
20
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
21
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
22
![](/Images/OutliningIndicators/InBlock.gif)
23
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
24
![](/Images/OutliningIndicators/InBlock.gif)
25
![](/Images/OutliningIndicators/InBlock.gif)
26
![](/Images/OutliningIndicators/InBlock.gif)
27
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
28
![](/Images/OutliningIndicators/InBlock.gif)
29
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
30
![](/Images/OutliningIndicators/InBlock.gif)
31
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
32
![](/Images/OutliningIndicators/InBlock.gif)
33
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
34
![](/Images/OutliningIndicators/InBlock.gif)
35
![](/Images/OutliningIndicators/InBlock.gif)
36
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
37
![](/Images/OutliningIndicators/InBlock.gif)
38
![](/Images/OutliningIndicators/InBlock.gif)
39
![](/Images/OutliningIndicators/InBlock.gif)
40
![](/Images/OutliningIndicators/InBlock.gif)
41
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
42
![](/Images/OutliningIndicators/InBlock.gif)
43
![](/Images/OutliningIndicators/InBlock.gif)
44
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
45
![](/Images/OutliningIndicators/InBlock.gif)
46
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
47
![](/Images/OutliningIndicators/InBlock.gif)
48
![](/Images/OutliningIndicators/InBlock.gif)
49
![](/Images/OutliningIndicators/InBlock.gif)
50
![](/Images/OutliningIndicators/InBlock.gif)
51
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
52
![](/Images/OutliningIndicators/InBlock.gif)
53
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
54
![](/Images/OutliningIndicators/InBlock.gif)
55
![](/Images/OutliningIndicators/InBlock.gif)
56
![](/Images/OutliningIndicators/InBlock.gif)
57
![](/Images/OutliningIndicators/InBlock.gif)
58
![](/Images/OutliningIndicators/InBlock.gif)
59
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
60
![](/Images/OutliningIndicators/InBlock.gif)
61
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
62
![](/Images/OutliningIndicators/InBlock.gif)
63
![](/Images/OutliningIndicators/InBlock.gif)
64
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
65
![](/Images/OutliningIndicators/InBlock.gif)
66
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
67
![](/Images/OutliningIndicators/InBlock.gif)
68
![](/Images/OutliningIndicators/InBlock.gif)
69
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
70
![](/Images/OutliningIndicators/InBlock.gif)
71
![](/Images/OutliningIndicators/InBlock.gif)
72
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
73
![](/Images/OutliningIndicators/InBlock.gif)
74
![](/Images/OutliningIndicators/InBlock.gif)
75
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
76
![](/Images/OutliningIndicators/InBlock.gif)
77
![](/Images/OutliningIndicators/InBlock.gif)
78
![](/Images/OutliningIndicators/InBlock.gif)
79
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
80
![](/Images/OutliningIndicators/InBlock.gif)
81
![](/Images/OutliningIndicators/InBlock.gif)
82
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
83
![](/Images/OutliningIndicators/InBlock.gif)
84
![](/Images/OutliningIndicators/InBlock.gif)
85
![](/Images/OutliningIndicators/InBlock.gif)
86
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
87
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
88
![](/Images/OutliningIndicators/InBlock.gif)
89
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
90
![](/Images/OutliningIndicators/InBlock.gif)
91
![](/Images/OutliningIndicators/InBlock.gif)
92
![](/Images/OutliningIndicators/InBlock.gif)
93
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
94
![](/Images/OutliningIndicators/InBlock.gif)
95
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
96
![](/Images/OutliningIndicators/InBlock.gif)
97
![](/Images/OutliningIndicators/InBlock.gif)
98
![](/Images/OutliningIndicators/InBlock.gif)
99
![](/Images/OutliningIndicators/InBlock.gif)
100
![](/Images/OutliningIndicators/InBlock.gif)
101
![](/Images/OutliningIndicators/InBlock.gif)
102
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
103
![](/Images/OutliningIndicators/InBlock.gif)
104
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
105
![](/Images/OutliningIndicators/InBlock.gif)
106
![](/Images/OutliningIndicators/InBlock.gif)
107
![](/Images/OutliningIndicators/InBlock.gif)
108
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
109
![](/Images/OutliningIndicators/InBlock.gif)
110
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
111
![](/Images/OutliningIndicators/InBlock.gif)
112
![](/Images/OutliningIndicators/InBlock.gif)
113
![](/Images/OutliningIndicators/InBlock.gif)
114
![](/Images/OutliningIndicators/InBlock.gif)
115
![](/Images/OutliningIndicators/InBlock.gif)
116
![](/Images/OutliningIndicators/InBlock.gif)
117
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
118
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
119
![](/Images/OutliningIndicators/ExpandedBlockEnd.gif)
120
![](/Images/OutliningIndicators/None.gif)
对于分治法的效率分析,有一个通用的公示可以使用:通用分治递推公式。