-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathThreeWaysAlgoVisualizer.java
117 lines (87 loc) · 3.19 KB
/
ThreeWaysAlgoVisualizer.java
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
import java.awt.*;
public class ThreeWaysAlgoVisualizer {
private static int DELAY = 20;
private ThreeWaysQuickSortData data;
private ThreeWaysAlgoFrame frame;
public ThreeWaysAlgoVisualizer(int sceneWidth, int sceneHeight, int N, ThreeWaysQuickSortData.Type dataType){
// 初始化数据
data = new ThreeWaysQuickSortData(N, sceneHeight, dataType);
// 初始化视图
EventQueue.invokeLater(() -> {
frame = new ThreeWaysAlgoFrame("Three Ways Quick Sort Visualization", sceneWidth, sceneHeight);
new Thread(() -> {
run();
}).start();
});
}
public ThreeWaysAlgoVisualizer(int sceneWidth, int sceneHeight, int N){
this(sceneWidth, sceneHeight, N, ThreeWaysQuickSortData.Type.Default);
}
public void run(){
setData(-1, -1, -1, -1, -1, -1);
quickSort3Ways(0, data.N()-1);
setData(-1, -1, -1, -1, -1, -1);
}
private void quickSort3Ways(int l, int r){
if( l > r )
return;
if( l == r ) {
setData(l, r, l, -1, -1, -1);
return;
}
setData(l, r, -1, -1, -1, -1);
// 随机在arr[l...r]的范围中, 选择一个数值作为标定点pivot
int p = (int)(Math.random()*(r-l+1)) + l;
setData(l, r, -1, p, -1, -1);
data.swap(l, p);
int v = data.get(l);
setData(l, r, -1, l, -1, -1);
int lt = l; // arr[l+1...lt] < v
int gt = r + 1; // arr[gt...r] > v
int i = l+1; // arr[lt+1...i) == v
setData(l, r, -1, l, lt, gt);
while( i < gt ){
if( data.get(i) < v ){
data.swap( i, lt+1);
i ++;
lt ++;
}
else if( data.get(i) > v ){
data.swap( i, gt-1);
gt --;
}
else // arr[i] == v
i ++;
setData(l, r, -1, l, i, gt);
}
data.swap( l, lt );
setData(l, r, lt, -1, -1, -1);
quickSort3Ways(l, lt-1 );
quickSort3Ways(gt, r);
}
private void setData(int l, int r, int fixedPivot, int curPivot, int curL, int curR){
data.l = l;
data.r = r;
if(fixedPivot != -1){
data.fixedPivots[fixedPivot] = true;
int i = fixedPivot;
while(i < data.N() && data.get(i) == data.get(fixedPivot)){
data.fixedPivots[i] = true;
i ++;
}
}
data.curPivot = curPivot;
data.curL = curL;
data.curR = curR;
frame.render(data);
AlgoVisHelper.pause(DELAY);
}
public static void main(String[] args) {
int sceneWidth = 800;
int sceneHeight = 800;
int N = 100;
// ThreeWaysAlgoVisualizer vis = new ThreeWaysAlgoVisualizer(sceneWidth, sceneHeight, N, ThreeWaysQuickSortData.Type.Default);
// ThreeWaysAlgoVisualizer vis = new ThreeWaysAlgoVisualizer(sceneWidth, sceneHeight, N, ThreeWaysQuickSortData.Type.NearlyOrdered);
ThreeWaysAlgoVisualizer vis = new ThreeWaysAlgoVisualizer(sceneWidth, sceneHeight, N, ThreeWaysQuickSortData.Type.Identical);
}
}