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
|
class Solution {
public:
vector<int> spiralOrder(vector<vector<int>> &matrix) {
vector<int> ans;
ans.clear();
if(matrix.size() <= 0) return ans;
int count = 0;
int sum = matrix.size() * matrix[0].size();
int px = 0;
int py = 0;
int xa = 0;
int xb = matrix.size() - 1;
int ya = 0;
int yb = matrix[0].size() - 1;
int dir = 0;
while(count < sum) {
ans.push_back(matrix[px][py]);
switch(dir) {
case 0:
if(py == yb) {
dir++;
dir %= 4;
xa++;
px++;
break;
}
py++;
if(py == yb) {
dir++;
dir %= 4;
xa++;
}
break;
case 1:
if(px == xb) {
dir++;
dir %= 4;
yb--;
py--;
break;
}
px++;
if(px == xb) {
dir++;
dir %= 4;
yb--;
}
break;
case 2:
if(py == ya) {
dir++;
dir %= 4;
xb--;
px--;
break;
}
py--;
if(py == ya) {
dir++;
dir %= 4;
xb--;
}
break;
case 3:
if(px == xa) {
dir++;
dir %= 4;
ya++;
py++;
break;
}
px--;
if(px == xa) {
dir++;
dir %= 4;
ya++;
}
break;
}
count++;
}
return ans;
}
};
|