-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathSpiral_Matrix.cpp
124 lines (107 loc) · 3.63 KB
/
Spiral_Matrix.cpp
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
118
119
120
121
122
123
124
/* Buggy Shit
class Solution {
public:
vector<int> spiralOrder(vector<vector<int> > &matrix) {
vector<int> result;
if(matrix.empty()) return result;
int m = matrix.size(), n = matrix[0].size();
int len = (m & 1) ? (m + 1) / 2 : m / 2;
int len2 = (n & 1) ? (n + 1) / 2 : n / 2;
for(int i = 0, j = 0; i < len and j < len2; ++i, ++j) {
for(int k = j; k < n - j; ++k)
result.push_back(matrix[i][k]);
for(int k = i + 1; k < m - i; ++k)
result.push_back(matrix[k][n - 1 - j]);
for(int k = n - 1 - j - 1; k >= j and m - i < m; --k)
result.push_back(matrix[m - 1 - i][k]);
for(int k = m - 1 - i - 1; k > i and j < n - 1; --k)
result.push_back(matrix[k][j]);
}
return result;
}
};
*/
// easy and concise solution
class Solution {
public:
vector<int> spiralOrder(vector<vector<int>>& matrix) {
vector<int> result;
if (matrix.empty()) {
return result;
}
int rowBegin = 0;
int rowEnd = matrix.size() - 1;
int colBegin = 0;
int colEnd = matrix[0].size() - 1;
while (rowBegin <= rowEnd and colBegin <= colEnd) {
// Traverse Right
for (int j = colBegin; j <= colEnd; j ++) {
result.push_back(matrix[rowBegin][j]);
}
rowBegin++;
// Traverse Down
for (int j = rowBegin; j <= rowEnd; j ++) {
result.push_back(matrix[j][colEnd]);
}
colEnd--;
if (rowBegin <= rowEnd) {
// Traverse Left
for (int j = colEnd; j >= colBegin; j --) {
result.push_back(matrix[rowEnd][j]);
}
}
rowEnd--;
if (colBegin <= colEnd) {
// Traver Up
for (int j = rowEnd; j >= rowBegin; j --) {
result.push_back(matrix[j][colBegin]);
}
}
colBegin ++;
}
return result;
}
};
class Solution {
public:
vector<int> spiralOrder(vector<vector<int> > &matrix) {
vector<int> res;
if (matrix.empty()) { return res; }
if (matrix.size()==1) { return matrix[0]; }
int m = matrix.size();
int n = matrix[0].size();
vector<vector<bool> > mask(m, vector<bool>(n, false));
int i = 0;
int j = 0;
int k = 0;
res.push_back(matrix[i][j]);
mask[0][0] = true;
while (k < m * n - 1) {
while ((j + 1 < n) and (mask[i][j + 1] == false)) {
j++;
k++;
res.push_back(matrix[i][j]);
mask[i][j] = true;
}
while ((i + 1 < m) and (mask[i + 1][j] == false)) {
i++;
k++;
res.push_back(matrix[i][j]);
mask[i][j] = true;
}
while ((j > 0) and (mask[i][j - 1] == false)) {
j--;
k++;
res.push_back(matrix[i][j]);
mask[i][j] = true;
}
while ((i > 0) and (mask[i - 1][j] == false)) {
i--;
k++;
res.push_back(matrix[i][j]);
mask[i][j] = true;
}
}
return res;
}
};