classSolution { public: vector<vector<int>> generateMatrix(int n) { int up = 0, down = n - 1, left = 0, right = n - 1; int count = 1; vector<vector<int>> vec(n, vector<int>(n, 0)); while (1) { for (int i = left; i <= right; i++) vec[up][i] = count++; if (++up > down) break; for (int i = up; i <= down; i++) vec[i][right] = count++; if (--right < left) break; for (int i = right; i >= left; i--) vec[down][i] = count++; if (--down < up) break; for (int i = down; i >= up; i--) vec[i][left] = count++; if (++left > right) break; } return vec; } };