leetcode 1975

1975: 最大方阵和

每次操作,恰好改变两个数的正负号;多次操作,恰好改变偶数个数的正负号。

分类讨论:

  • 如果 matrix 有偶数个负数,那么可以把所有数都变成非负数。
  • 如果 matrix 有奇数个负数且没有 0,那么最终必然剩下奇数个负数,剩下一个负数是最优的。贪心地,++选择 matrix 中的绝对值最小的数(最小的负数)++,给它加上负号。
  • 如果 matrix 有奇数个负数且有 0,那么可以把一个 0 和最终剩下的一个负数操作一次,从而把所有数都变成非负数。

代码实现时,无需特判是否有 0。如果有 0,则代码中的 mn=0,对 ans 无影响。

复制代码
class Solution {
public:
    long long maxMatrixSum(vector<vector<int>>& matrix) {
        long long ans=0;
        int neg_cnt=0,mn=INT_MAX;
        for(auto& row:matrix){ //一行一行看
            for(int x:row){
                if(x<0){
                    neg_cnt++;
                    x=-x; //先把负数都变成正数
                }
                mn=min(mn,x);
                ans+=x;
            }
        }
        if(neg_cnt%2==1){
            //奇数个负数,给绝对值最小的数添加负号
            ans-=mn*2;
        }

        return ans;
    }
};
相关推荐
Z1Jxxx6 分钟前
C++ P1150 Peter 的烟
数据结构·c++·算法
踮起脚看烟花13 分钟前
chapter10_泛型算法
c++·算法
笨笨饿13 分钟前
# 52_浅谈为什么工程基本进入复数域?
linux·服务器·c语言·数据结构·人工智能·算法·学习方法
Code-keys14 分钟前
ADSP/ARM 性能/稳定性排查专栏总述
arm开发·算法·边缘计算·dsp开发
山栀shanzhi17 分钟前
C++四大常见排序对比
c++·算法·排序算法
Allen_LVyingbo31 分钟前
量子测量三部曲:投影测量、POVM 与坍缩之谜—从形式主义到物理图像
算法·性能优化·健康医疗·量子计算·空间计算
qiqsevenqiqiqiqi36 分钟前
位运算 计算
算法
甄心爱学习1 小时前
【最优化】1-6章习题
人工智能·算法
PD我是你的真爱粉1 小时前
向量数据库原理与检索算法入门:ANN、HNSW、LSH、PQ 与相似度计算
数据库·人工智能·算法
汀、人工智能1 小时前
[特殊字符] 第72课:杨辉三角
数据结构·算法·数据库架构·图论·bfs·杨辉三角