题目描述

有一个二维矩阵 其中每个元素的值为

移动是指选择任一行或列,并转换该行或列中的每一个值:将所有 都更改为 ,将所有 都更改为

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

返回尽可能高的分数。

示例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

提示

题解

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

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

二进制枚举

因为行列数最多 ,所以我们可以枚举每一行的翻转状态(:不翻转,:翻转)。

然后对于每一列,我们只需要看不翻转的 多,还是翻转后 多就行了。

这样的时间复杂度是 ,极限情况下是 左右,还是可能会超时的。

贪心

再仔细观察,我们可以发现要想最终和最大,第一列必须全为

证明很简单,对于任意一行,如果它的第一位是 ,那么这一位的二进制数值就是 。反之如果这一位是 ,那么即使后面所有位全为 ,总数值也只能达到 。所以第一位是一定要为 的。

这样就很简单了,每一行的翻转情况其实是确定的。如果第一位是 ,就不翻转,否则就翻转。

然后每一列还是看不翻转的 多,还是翻转后 多。

这样的时间复杂度只有

那么可能有人会问:为啥不把每行第一位全翻转为 ,然后翻转第一列使得每行第一位全 呢?其实这样是等价的,完全就相当于将之前的方法倒转过来(翻转不翻转操作颠倒)。

代码

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;}
};

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

  1. leetcode 861. 翻转矩阵后的得分(贪心算法)

    有一个二维矩阵 A 其中每个元素的值为 0 或 1 . 移动是指选择任一行或列,并转换该行或列中的每一个值:将所有 0 都更改为 1,将所有 1 都更改为 0. 在做出任意次数的移动后,将该矩阵的每一 ...

  2. LeetCode 861. 翻转矩阵后的得分(贪心)

    1. 题目 有一个二维矩阵 A 其中每个元素的值为 0 或 1 . 移动是指选择任一行或列,并转换该行或列中的每一个值:将所有 0 都更改为 1,将所有 1 都更改为 0. 在做出任意次数的移动后,将 ...

  3. leetcode 861. 翻转矩阵后的得分

    目录 题目描述: 示例: 解法: 题目描述: 有一个二维矩阵 A 其中每个元素的值为 0 或 1 . 移动是指选择任一行或列,并转换该行或列中的每一个值:将所有 0 都更改为 1,将所有 1 都更改为 ...

  4. LeetCode——861. 翻转矩阵后的得分(贪心)

    题目描述: 解题思路: 给定一个翻转方案,则它们之间任意交换顺序后,得到的结果保持不变.因此,我们总可以先考虑所有的行翻转,再考虑所有的列翻转. 为了使最大,第一列要先全变成1,然后后面的列,如果0比 ...

  5. 将矩阵转为一行_LeetCode 力扣官方题解 | 861. 翻转矩阵后的得分

    点击上方蓝字设为星标 下面开始今天的学习- 力扣  861. 翻转矩阵后的得分(点击文末阅读原文查看题目)题目描述有一个二维矩阵 A 其中每个元素的值为 0 或 1 .移动是指选择任一行或列,并转换该 ...

  6. Leetcode861翻转矩阵后的得分(C++题解):贪心

    文章目录 861. 翻转矩阵后的得分 题目大意: 只有值为0或1的二维数组,可以进行每行或者每列的01反转,每行中的0全部变成1,与此同时该行的1全部变成0. 若把每一行看作1个二进制数,求经过翻转后 ...

  7. 重复次数最多的 子串_每日算法系列【LeetCode 424】替换后的最长重复字符

    题目描述 给你一个仅由大写英文字母组成的字符串,你可以将任意位置上的字符替换成另外的字符,总共可最多替换 k 次.在执行上述操作后,找到包含重复字母的最长子串的长度. 示例1 输入: s = &quo ...

  8. java回文数算法for_【Java】【每日算法/刷穿 LeetCode】9. 回文数(简单)

    首页 专栏 java 文章详情 0 [每日算法/刷穿 LeetCode]9. 回文数(简单) 宫水三叶发布于 今天 15:30 题目描述 判断一个整数是否是回文数.回文数是指正序(从左向右)和倒序(从 ...

  9. 整数反转leetcode java_【Java】【每日算法/刷穿 LeetCode】7. 整数反转(简单)

    首页 专栏 java 文章详情 0 [每日算法/刷穿 LeetCode]7. 整数反转(简单) 宫水三叶发布于 今天 12:10 题目描述 给出一个 32 位的有符号整数,你需要将这个整数中每位上的数 ...

  10. java编写字母z算法_【Java】【每日算法/刷穿 LeetCode】6. Z 字形变换(中等)

    首页 专栏 java 文章详情 0 [每日算法/刷穿 LeetCode]6. Z 字形变换(中等) 宫水三叶发布于 今天 12:03 题目描述 将一个给定字符串 s 根据给定的行数 numRows , ...

最新文章

  1. DVWA手记——取消登录
  2. STM32串口USART1的使用方法
  3. 在云中使用 MapReduce 和负载平衡
  4. c++中vector使用说明
  5. Xcode代码提示联想功能失效,按command键点不进去类库,提示“?”
  6. android有关医疗实现功能,基于Android的智能医疗监测系统的设计与实现_问答库
  7. NB-IoT---(0) NB-IoT技术
  8. 靠谱测试人员需具备沟通表达能力
  9. 培训学web前端前景如何?
  10. Android内核开发:理解和掌握repo工具
  11. HTML5写的简单小游戏-绵羊快跑
  12. Redis之利用锁机制来防止缓存过期产生的惊群现象
  13. K8S集群Calico网络组件报错BIRD is not ready: BGP not established with
  14. 【Unity3D插件】Exploder插件分享《物体爆炸效果插件》
  15. 基于java实现学科竞赛管理系统「Springboot+mybatis+lyaui」
  16. 每日一淘洞察市场消费真相,深挖三四五线城市消费者需求
  17. 软文广告的写作技巧分析!
  18. 然后上传到linux主机上,Xshell实现Windows上传文件到Linux主机
  19. 苹果微信多开_简易版!微信电脑端多开方法!!!
  20. 使用阿里云OSS完成文件的上传样例

热门文章

  1. 【JAVA】虚拟机指令集
  2. Qt 程序打包发布总结 转
  3. Android怎样实现毛玻璃效果之Android高级模糊技术
  4. SQL的别名和SQL的执行顺序和SQL优化
  5. Server的Transfer和Response的Redirect
  6. Linux操作系统中vi常见用法和相关配置
  7. 算法基础:BFS和DFS的直观解释
  8. jQuery焦点图插件
  9. Scrapy爬取小说简单逻辑
  10. 利用Pelican搭建个人博客