-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUsefulHeap.c
81 lines (70 loc) · 1.41 KB
/
UsefulHeap.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#include "UsefulHeap.h"
void HeapInit(Heap * ph, PriorityComp pc)
{
ph->numOfData = 0;
ph->comp = pc;
}
int HIsEmpty(Heap * ph)
{
if(ph->numOfData)
return FALSE;
return TRUE;
}
int GetParentIDX(int idx)
{
return idx/2;
}
int GetLChildIDX(int idx)
{
return idx*2;
}
int GetRChildIDX(int idx)
{
return GetLChildIDX(idx)+1;
}
int GetHiPriChildIDX(Heap * ph, int idx)
{
if(GetLChildIDX(idx) > ph->numOfData)
return 0;
else if(GetLChildIDX(idx) == ph->numOfData)
return ph->numOfData;
else
if(ph->comp(ph->heapArr[GetLChildIDX(idx)], ph->heapArr[GetRChildIDX(idx)]) < 0)
return GetRChildIDX(idx);
else
return GetLChildIDX(idx);
}
void HInsert(Heap * ph, HData data)
{
int idx = (ph->numOfData)+1;
while(idx!=1)
if(ph->comp(data, ph->heapArr[GetParentIDX(idx)]) > 0)
{
ph->heapArr[idx] = ph->heapArr[GetParentIDX(idx)];
idx = GetParentIDX(idx);
}
else
break;
(ph->numOfData)++;
ph->heapArr[idx] = data;
}
HData HDelete(Heap * ph)
{
HData rdata = ph->heapArr[1];
HData ldata = ph->heapArr[(ph->numOfData)];
int parentIdx = 1;
int childIdx;
while(childIdx = GetHiPriChildIDX(ph, parentIdx))
{
if(ph->comp(ldata, ph->heapArr[childIdx]) >= 0)
break;
else
{
ph->heapArr[parentIdx] = ph->heapArr[childIdx];
parentIdx = childIdx;
}
}
(ph->numOfData)--;
ph->heapArr[parentIdx] = ldata;
return rdata;
}