classSolution { public: vector<vector<int>> transpose(vector<vector<int>>& matrix) { int R = matrix.size(), C = matrix[0].size(); vector<vector<int>> ans(C, vector<int>(R)); for (int r = 0; r < R; ++r) for (int c = 0; c < C; ++c) ans[c][r] = matrix[r][c]; return ans; } };
classSolution { public: vector<vector<int>> flipAndInvertImage(vector<vector<int>>& A) { int n = A.size(); for (int i = 0; i < n; ++i) { int left = 0, right = n - 1; while (left < right) { if (A[i][left] == A[i][right]) { A[i][left] ^= 1; A[i][right] ^= 1; } ++left; --right; } if (left == right) A[i][left] ^= 1; } return A; } };
classSolution { public: intminKBitFlips(vector<int>& A, int K){ int n = A.size(), flipped = 0, ans = 0; vector<int> isFlipped(n); for (int i = 0; i < n; ++i) { if (i >= K) flipped ^= isFlipped[i - K]; if (flipped == A[i]) { if (i + K > n) return-1; isFlipped[i] = 1; flipped ^= 1; ++ans; } } return ans; } };
classSolution { public: intminKBitFlips(vector<int>& A, int K){ int n = A.size(), flipped = 0, ans = 0; queue<int> isFlipped; for (int i = 0; i < n; ++i) { if (i >= K) { flipped ^= isFlipped.front(); isFlipped.pop(); } if (flipped == A[i]) { if (i + K > n) return-1; isFlipped.push(1); flipped ^= 1; ++ans; } else { isFlipped.push(0); } } return ans; } };
classSolution { public: intminKBitFlips(vector<int>& A, int K){ // "cur" is the count of flipping times within current sliding window. int n = A.size(), cur = 0, ans = 0; for (int i = 0; i < n; ++i) { if (i >= K && A[i - K] > 1) { --cur; A[i - K] += 2; } if (cur % 2 == A[i]) { if (i + K > n) return-1; A[i] += 2; ++cur; ++ans; } } return ans; } };