0
点赞
收藏
分享

微信扫一扫

【每日算法Day 64】LeetCode 861. 翻转矩阵后的得分


题目描述

【每日算法Day 64】LeetCode 861. 翻转矩阵后的得分_时间复杂度

在做出任意次数的移动后,将该矩阵的每一行都按照二进制数来解释,矩阵的得分就是这些数字的总和。

返回尽可能高的分数。

示例1


输入:
[[0,0,1,1],[1,0,1,0],[1,1,0,0]]
输出:
39
解释:
转换为 [[1,1,1,1],[1,0,0,1],[1,1,1,1]]
0b1111 + 0b1001 + 0b1111 = 15 + 9 + 15 = 39


提示

【每日算法Day 64】LeetCode 861. 翻转矩阵后的得分_时间复杂度_02

题解

首先我们要明确一个显而易见的事实:

  • 每一行、每一列要么不翻转,要么翻转一次,再多是等价的,没有意义。

二进制枚举

【每日算法Day 64】LeetCode 861. 翻转矩阵后的得分_二进制数_03

代码

c++


class Solution {
public:
int matrixScore(vector<vector<int>>& A) {
int n = A.size(), m = A[0].size();
for (int i = 0; i < n; ++i) {
if (A[i][0]) continue;
for (int j = 0; j < m; ++j) {
A[i][j] ^= 1;
}
}
int res = (1<<(m-1)) * n;
for (int j = 1; j < m; ++j) {
int cnt = 0;
for (int i = 0; i < n; ++i) {
cnt += A[i][j];
}
cnt = max(cnt, n-cnt);
res += (1<<(m-1-j)) * cnt;
}
return res;
}
};


举报

相关推荐

0 条评论