leetcode 1931 二维涂色问题 降维dp解法+状态压缩

在这里插入图片描述
题目的话,就是咱们高中经常做的涂色问题,一共三种颜色。

最直观的感觉:不就是dp吗,考虑左边和上面的元素不就行了。但这样完全是不行的,2*2的我还能做,但是3*3除了枚举我已经无法得出正确答案了。

这个题正确的做法是降维,因为有一个维度题目给的数据范围是 <= 5的,就针对这个处理。我们考虑一整行的状态转移,对于维度m,一行的可能性一共有 3 ∗ 2 m − 1 3*2^{m-1} 32m1种。

对每一行,我们可以用一个数字来存,因为只有5位,用10进制状态压缩即可。判断是否可转移,我们只需要判断每一位是否相等,都不相等说明可以从一行转移到另一行。

代码如下:

typedef long long ll;
class Solution {
   
vector<int> types;
public:
    void dfs(int m, int ct, int last, int num
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值