3122.使矩阵满足条件的最少操作次数

周赛第三题,知道要用动态规划,但是不知道怎么回到子问题

显然根据题意我们需要让每一列都相同,但是相邻列不能选择同一种数字,观察到数据nums[i]介于0-9,我们就以此为突破口.

首先我们用count[n][10], count[i][j]记录第i+1列值为j的元素个数,转移方程如下:

dfs(i,pre) = max(dfs(i-1,k) + count[i][k]) k=0,1...9 k!=pre;

表示 i 对应的那一列选择k的话, 再去判断i-1对应的那一列的元素

入口是dfs(n-1,10); 使用10是表示没有上一个,取0-9均可

代码如下: 这里写的是 记忆化回溯 ,可以自行改成二维dp

复制代码
class Solution {
public:
    int minimumOperations(vector<vector<int>>& grid) {
        int m=grid.size(),n=grid[0].size();
        int count[n][10]; //count[i][j] 表示 第i+1列里面值等于j的个数
        memset(count,0,sizeof(count));
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                count[j][grid[i][j]]++;
            }
        } 
        int memo[n][11];
        memset(memo,-1,sizeof(memo));
        function<int(int,int)> dfs=[&](int i,int pre){  
            if(i==-1) return 0;
            int &res=memo[i][pre];
            if(res!=-1) return res;
            int cnt=0;
            for(int j=0;j<10;j++){
                if(j==pre) continue; 
                cnt=max(cnt,dfs(i-1,j)+count[i][j]);//[[1,6,7,3,0,4,1,3,7,5]]
            } 
            return res=cnt;
        };
        return m*n-dfs(n-1,10);
    }
};
相关推荐
YYuCChi12 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
罗湖老棍子14 小时前
括号配对(信息学奥赛一本通- P1572)
算法·动态规划·区间dp·字符串匹配·区间动态规划
一只小小的芙厨15 小时前
寒假集训笔记·树上背包
c++·笔记·算法·动态规划
金融RPA机器人丨实在智能15 小时前
2026动态规划新风向:实在智能Agent如何以自适应逻辑重构企业效率?
算法·ai·重构·动态规划
问好眼16 小时前
【信息学奥赛一本通】1275:【例9.19】乘积最大
c++·算法·动态规划·信息学奥赛
菜鸟233号20 小时前
力扣647 回文子串 java实现
java·数据结构·leetcode·动态规划
葵花楹21 小时前
【算法题】【动态规划2】【背包动态规划】
算法·动态规划
2501_924878731 天前
企业级营销安全防线:AdAgent 合规风控体系设计与实践
人工智能·逻辑回归·动态规划
觅特科技-互站1 天前
陌讯视觉‘动态密度流’模型:亚运场馆到前海政务厅,98.6%聚众事件5秒精准定位|技术拆解+SDK实录
逻辑回归·动态规划
沉睡的无敌雄狮2 天前
生态即壁垒:陌讯视觉‘开箱即战’背后的OSI七层协同架构
逻辑回归·动态规划