Skip to content

Commit

Permalink
Create remove-all-ones-with-row-and-column-flips-ii.cpp
Browse files Browse the repository at this point in the history
  • Loading branch information
kamyu104 authored Feb 17, 2022
1 parent 50dd117 commit 96ec2dd
Showing 1 changed file with 58 additions and 0 deletions.
58 changes: 58 additions & 0 deletions C++/remove-all-ones-with-row-and-column-flips-ii.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
// Time: O(m * n * 2^(m * n))
// Space: O(2^(m * n))

// dp, bitmasks
class Solution {
public:
int removeOnes(vector<vector<int>>& grid) {
static const int INF = numeric_limits<int>::max();

vector<int> rows(size(grid));
int bit = 1;
for (int i = 0; i < size(grid); ++i) {
int mask = 0;
for (int j = 0; j < size(grid[0]); ++j) {
mask += bit;
bit <<= 1;
}
rows[i] = mask;
}
vector<int> cols(size(grid[0]));
bit = 1;
for (int j = 0; j < size(grid[0]); ++j) {
int mask = 0;
int bit2 = bit;
for (int i = 0; i < size(grid); ++i) {
mask += bit2;
bit2 <<= size(grid[0]);
}
cols[j] = mask;
bit <<= 1;
}
int full_mask = (1 << (size(grid) * size(grid[0]))) - 1;
vector<vector<int>> masks(size(grid), vector<int>(size(grid[0]), full_mask));
int target = 0;
bit = 1;
for (int i = 0; i < size(grid); ++i) {
for (int j = 0; j < size(grid[0]); ++j) {
target += bit * grid[i][j];
masks[i][j] -= (rows[i] + cols[j] - bit);
bit <<= 1;
}
}
vector<int> dp(target + 1, INF);
dp[0] = 0;
for (int mask = 1; mask <= target; ++mask) {
for (int i = 0; i < size(grid); ++i) {
for (int j = 0; j < size(grid[0]); ++j) {
if (grid[i][j]) {
if (dp[mask & masks[i][j]] != INF) {
dp[mask] = min(dp[mask], dp[mask & masks[i][j]] + 1);
}
}
}
}
}
return dp[target];
}
};

0 comments on commit 96ec2dd

Please sign in to comment.