1
using
System;
2
using
System.Collections.Generic;
3
using
System.Text;
4![](/Images/OutliningIndicators/None.gif)
5
namespace
Heap
6
{
7
class Program
8
{
9
static void Main(string[] args)
10
{
11
int len = 100;
12
Heap heap = new Heap();
13
14
Random random = new Random();
15![](/Images/OutliningIndicators/InBlock.gif)
16
for (int i = 0; i < len; i++)
17
{
18
int data = random.Next(1, 100000);
19
heap.Insert(data);
20
}
21![](/Images/OutliningIndicators/InBlock.gif)
22
for (int i = 0; i < len; i++)
23
{
24
int data = heap.Delete();
25
System.Console.WriteLine(data);
26
}
27
28
System.Console.WriteLine("ok");
29
}
30
}
31![](/Images/OutliningIndicators/InBlock.gif)
32
class Heap
33
{
34
private List<int> _nodes;
35![](/Images/OutliningIndicators/InBlock.gif)
36
public Heap()
37
{
38
_nodes = new List<int>();
39
}
40![](/Images/OutliningIndicators/InBlock.gif)
41
public void Insert(int data)
42
{
43
_nodes.Add(data);
44![](/Images/OutliningIndicators/InBlock.gif)
45
chechUp(_nodes.Count - 1);
46
}
47![](/Images/OutliningIndicators/InBlock.gif)
48
private void chechUp(int downIndex)
49
{
50
int parentIndex;
51![](/Images/OutliningIndicators/InBlock.gif)
52
while ( (parentIndex = getParentIndex(downIndex)) != -1)
53
{
54
if (_nodes[downIndex] > _nodes[parentIndex])
55
{
56
int data = _nodes[downIndex];
57
_nodes[downIndex] = _nodes[parentIndex];
58
_nodes[parentIndex] = data;
59![](/Images/OutliningIndicators/InBlock.gif)
60
downIndex = parentIndex;
61
}
62
else
63
{
64
break;
65
}
66
}
67
}
68![](/Images/OutliningIndicators/InBlock.gif)
69
public int Delete()
70
{
71
if (_nodes.Count == 0)
72
{
73
throw new Exception("no more element to delete.");
74
}
75![](/Images/OutliningIndicators/InBlock.gif)
76
int data = _nodes[0];
77![](/Images/OutliningIndicators/InBlock.gif)
78
_nodes[0] = _nodes[_nodes.Count - 1];
79![](/Images/OutliningIndicators/InBlock.gif)
80
_nodes.RemoveAt(_nodes.Count - 1);
81![](/Images/OutliningIndicators/InBlock.gif)
82
chechDown(0);
83![](/Images/OutliningIndicators/InBlock.gif)
84
return data;
85
}
86![](/Images/OutliningIndicators/InBlock.gif)
87
private void chechDown(int upIndex)
88
{
89
int lChildIndex;
90
int rChildIndex;
91
int downIndex;
92
93
lChildIndex = getLChildIndex(upIndex);
94
rChildIndex = getRChildIndex(upIndex);
95![](/Images/OutliningIndicators/InBlock.gif)
96
while (lChildIndex != -1)
97
{
98
//只考虑父节点和左子树的关系
99
if (rChildIndex == -1)
100
{
101
downIndex = lChildIndex;
102
}
103
else
104
{
105
downIndex = _nodes[lChildIndex] > _nodes[rChildIndex] ? lChildIndex : rChildIndex;
106
}
107![](/Images/OutliningIndicators/InBlock.gif)
108
if (_nodes[upIndex] < _nodes[downIndex])
109
{
110
int data = _nodes[downIndex];
111
_nodes[downIndex] = _nodes[upIndex];
112
_nodes[upIndex] = data;
113![](/Images/OutliningIndicators/InBlock.gif)
114
upIndex = downIndex;
115![](/Images/OutliningIndicators/InBlock.gif)
116
lChildIndex = getLChildIndex(upIndex);
117
rChildIndex = getRChildIndex(upIndex);
118
}
119
else
120
{
121
break;
122
}
123![](/Images/OutliningIndicators/InBlock.gif)
124
}
125![](/Images/OutliningIndicators/InBlock.gif)
126![](/Images/OutliningIndicators/InBlock.gif)
127
}
128![](/Images/OutliningIndicators/InBlock.gif)
129
private int getLChildIndex(int parentIndex)
130
{
131
int lChildIndex = parentIndex * 2;
132![](/Images/OutliningIndicators/InBlock.gif)
133
lChildIndex += 1;
134![](/Images/OutliningIndicators/InBlock.gif)
135
return lChildIndex <= _nodes.Count - 1 ? lChildIndex : -1;
136
}
137![](/Images/OutliningIndicators/InBlock.gif)
138
private int getRChildIndex(int parentIndex)
139
{
140
int rChildIndex = parentIndex * 2;
141![](/Images/OutliningIndicators/InBlock.gif)
142
rChildIndex += 2;
143![](/Images/OutliningIndicators/InBlock.gif)
144
return rChildIndex <= _nodes.Count - 1 ? rChildIndex : -1;
145
}
146![](/Images/OutliningIndicators/InBlock.gif)
147
/// <summary>
148
/// 如果该节点是跟节点,则无法给出其父节点,故以-1代替。
149
/// </summary>
150
/// <param name="childIndex"></param>
151
/// <returns></returns>
152
private int getParentIndex(int childIndex)
153
{
154
// 如果该节点是跟节点,则无法给出其父节点,故以-1代替。
155
if (childIndex == 0)
156
{
157
return -1;
158
}
159![](/Images/OutliningIndicators/InBlock.gif)
160
childIndex++;
161![](/Images/OutliningIndicators/InBlock.gif)
162
//向下取整
163
return (int)(childIndex / 2) - 1;
164
}
165
}
166![](/Images/OutliningIndicators/InBlock.gif)
167
class HeapNode
168
{
169
public int _data;
170
public HeapNode _parent;
171
public HeapNode _lChild;
172
public HeapNode _rChild;
173![](/Images/OutliningIndicators/InBlock.gif)
174
public HeapNode(int data)
175
{
176
_data = data;
177
_parent = null;
178
_lChild = null;
179
_rChild = null;
180
}
181
}
182![](/Images/OutliningIndicators/InBlock.gif)
183
}
184
![](/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/InBlock.gif)
14
![](/Images/OutliningIndicators/InBlock.gif)
15
![](/Images/OutliningIndicators/InBlock.gif)
16
![](/Images/OutliningIndicators/InBlock.gif)
17
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
18
![](/Images/OutliningIndicators/InBlock.gif)
19
![](/Images/OutliningIndicators/InBlock.gif)
20
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
21
![](/Images/OutliningIndicators/InBlock.gif)
22
![](/Images/OutliningIndicators/InBlock.gif)
23
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
24
![](/Images/OutliningIndicators/InBlock.gif)
25
![](/Images/OutliningIndicators/InBlock.gif)
26
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
27
![](/Images/OutliningIndicators/InBlock.gif)
28
![](/Images/OutliningIndicators/InBlock.gif)
29
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
30
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
31
![](/Images/OutliningIndicators/InBlock.gif)
32
![](/Images/OutliningIndicators/InBlock.gif)
33
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
34
![](/Images/OutliningIndicators/InBlock.gif)
35
![](/Images/OutliningIndicators/InBlock.gif)
36
![](/Images/OutliningIndicators/InBlock.gif)
37
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
38
![](/Images/OutliningIndicators/InBlock.gif)
39
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
40
![](/Images/OutliningIndicators/InBlock.gif)
41
![](/Images/OutliningIndicators/InBlock.gif)
42
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
43
![](/Images/OutliningIndicators/InBlock.gif)
44
![](/Images/OutliningIndicators/InBlock.gif)
45
![](/Images/OutliningIndicators/InBlock.gif)
46
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
47
![](/Images/OutliningIndicators/InBlock.gif)
48
![](/Images/OutliningIndicators/InBlock.gif)
49
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
50
![](/Images/OutliningIndicators/InBlock.gif)
51
![](/Images/OutliningIndicators/InBlock.gif)
52
![](/Images/OutliningIndicators/InBlock.gif)
53
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
54
![](/Images/OutliningIndicators/InBlock.gif)
55
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
56
![](/Images/OutliningIndicators/InBlock.gif)
57
![](/Images/OutliningIndicators/InBlock.gif)
58
![](/Images/OutliningIndicators/InBlock.gif)
59
![](/Images/OutliningIndicators/InBlock.gif)
60
![](/Images/OutliningIndicators/InBlock.gif)
61
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
62
![](/Images/OutliningIndicators/InBlock.gif)
63
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
64
![](/Images/OutliningIndicators/InBlock.gif)
65
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
66
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
67
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
68
![](/Images/OutliningIndicators/InBlock.gif)
69
![](/Images/OutliningIndicators/InBlock.gif)
70
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
71
![](/Images/OutliningIndicators/InBlock.gif)
72
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
73
![](/Images/OutliningIndicators/InBlock.gif)
74
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
75
![](/Images/OutliningIndicators/InBlock.gif)
76
![](/Images/OutliningIndicators/InBlock.gif)
77
![](/Images/OutliningIndicators/InBlock.gif)
78
![](/Images/OutliningIndicators/InBlock.gif)
79
![](/Images/OutliningIndicators/InBlock.gif)
80
![](/Images/OutliningIndicators/InBlock.gif)
81
![](/Images/OutliningIndicators/InBlock.gif)
82
![](/Images/OutliningIndicators/InBlock.gif)
83
![](/Images/OutliningIndicators/InBlock.gif)
84
![](/Images/OutliningIndicators/InBlock.gif)
85
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
86
![](/Images/OutliningIndicators/InBlock.gif)
87
![](/Images/OutliningIndicators/InBlock.gif)
88
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
89
![](/Images/OutliningIndicators/InBlock.gif)
90
![](/Images/OutliningIndicators/InBlock.gif)
91
![](/Images/OutliningIndicators/InBlock.gif)
92
![](/Images/OutliningIndicators/InBlock.gif)
93
![](/Images/OutliningIndicators/InBlock.gif)
94
![](/Images/OutliningIndicators/InBlock.gif)
95
![](/Images/OutliningIndicators/InBlock.gif)
96
![](/Images/OutliningIndicators/InBlock.gif)
97
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
98
![](/Images/OutliningIndicators/InBlock.gif)
99
![](/Images/OutliningIndicators/InBlock.gif)
100
![](/Images/OutliningIndicators/ExpandedSubBlockStart.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/ExpandedSubBlockEnd.gif)
107
![](/Images/OutliningIndicators/InBlock.gif)
108
![](/Images/OutliningIndicators/InBlock.gif)
109
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
110
![](/Images/OutliningIndicators/InBlock.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/InBlock.gif)
118
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
119
![](/Images/OutliningIndicators/InBlock.gif)
120
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
121
![](/Images/OutliningIndicators/InBlock.gif)
122
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
123
![](/Images/OutliningIndicators/InBlock.gif)
124
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
125
![](/Images/OutliningIndicators/InBlock.gif)
126
![](/Images/OutliningIndicators/InBlock.gif)
127
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
128
![](/Images/OutliningIndicators/InBlock.gif)
129
![](/Images/OutliningIndicators/InBlock.gif)
130
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
131
![](/Images/OutliningIndicators/InBlock.gif)
132
![](/Images/OutliningIndicators/InBlock.gif)
133
![](/Images/OutliningIndicators/InBlock.gif)
134
![](/Images/OutliningIndicators/InBlock.gif)
135
![](/Images/OutliningIndicators/InBlock.gif)
136
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
137
![](/Images/OutliningIndicators/InBlock.gif)
138
![](/Images/OutliningIndicators/InBlock.gif)
139
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
140
![](/Images/OutliningIndicators/InBlock.gif)
141
![](/Images/OutliningIndicators/InBlock.gif)
142
![](/Images/OutliningIndicators/InBlock.gif)
143
![](/Images/OutliningIndicators/InBlock.gif)
144
![](/Images/OutliningIndicators/InBlock.gif)
145
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
146
![](/Images/OutliningIndicators/InBlock.gif)
147
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
148
![](/Images/OutliningIndicators/InBlock.gif)
149
![](/Images/OutliningIndicators/InBlock.gif)
150
![](/Images/OutliningIndicators/InBlock.gif)
151
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
152
![](/Images/OutliningIndicators/InBlock.gif)
153
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
154
![](/Images/OutliningIndicators/InBlock.gif)
155
![](/Images/OutliningIndicators/InBlock.gif)
156
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
157
![](/Images/OutliningIndicators/InBlock.gif)
158
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
159
![](/Images/OutliningIndicators/InBlock.gif)
160
![](/Images/OutliningIndicators/InBlock.gif)
161
![](/Images/OutliningIndicators/InBlock.gif)
162
![](/Images/OutliningIndicators/InBlock.gif)
163
![](/Images/OutliningIndicators/InBlock.gif)
164
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
165
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
166
![](/Images/OutliningIndicators/InBlock.gif)
167
![](/Images/OutliningIndicators/InBlock.gif)
168
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
169
![](/Images/OutliningIndicators/InBlock.gif)
170
![](/Images/OutliningIndicators/InBlock.gif)
171
![](/Images/OutliningIndicators/InBlock.gif)
172
![](/Images/OutliningIndicators/InBlock.gif)
173
![](/Images/OutliningIndicators/InBlock.gif)
174
![](/Images/OutliningIndicators/InBlock.gif)
175
![](/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
176
![](/Images/OutliningIndicators/InBlock.gif)
177
![](/Images/OutliningIndicators/InBlock.gif)
178
![](/Images/OutliningIndicators/InBlock.gif)
179
![](/Images/OutliningIndicators/InBlock.gif)
180
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
181
![](/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
182
![](/Images/OutliningIndicators/InBlock.gif)
183
![](/Images/OutliningIndicators/ExpandedBlockEnd.gif)
184
![](/Images/OutliningIndicators/None.gif)