动态规划--栅栏染色

514. 栅栏染色

我们有一个栅栏,它有n个柱子,现在要给柱子染色,有k种颜色可以染。
必须保证不存在超过2个相邻的柱子颜色相同,求有多少种染色方案。

样例

n = 3, k = 2, return 6

      post 1,   post 2, post 3
way1    0         0       1 
way2    0         1       0
way3    0         1       1
way4    1         0       0
way5    1         0       1
way6    1         1       0

注意事项

nk都是非负整数

解题思路:题目的意思应该是,最多允许两个相邻的柱子颜色相同。假设我们现在正处于第i个柱子,面临的问题是怎么涂色?我们不可能预知将来会发生什么,只能根据涂过的柱子来决定第i个柱子的颜色。考虑第i个柱子前面的那两个柱子的染色情况,

分为两种情况:当前面的这两个柱子染色相同,则必须保证第i个柱子染色与前两个不一样,也就是第i个位置有k*(k-1)种方案;如果染色不同的话,第i个柱子就随便染了,有k*(k-1)*k种方案。

照着上面的思路进行写代码的话,判断的情况会非常多(可能玩了一个假的动态规划)。继续从第i个柱子进行分析,第i-1个柱子与他连在一块,判断他俩的染色?试试。。

同样分为两种情况:

1.染色相同,则第i-2个柱子必须颜色不相同。则有k*(k-1)种方案。

2.染色不同的话,则第i-2个柱子颜色就不做要求了,有k*k*(k-1)种方案。

代码:

public class Solution {
    /**
     * @param n: non-negative integer, n posts
     * @param k: non-negative integer, k colors
     * @return: an integer, the total number of ways
     */
    public int numWays(int n, int k) {
        // write your code here
        if(n==0||k==0)
            return 0;
        if(n==1)
            return k;
        int dp[] = new int[n+1];
        dp[1] = k;
        dp[2] = k*k;
        for(int i=3;i<n+1;i++)
            dp[i] = dp[i-1]*(k-1)+dp[i-2]*(k-1);
        return dp[n];
    }
}

完美解决。

感悟:高中数学老师曾经说过:当你解决一个问题,越解决越麻烦的话,你就得考虑一下你的方法了。但是撞一下南墙也是挺好的。。。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
STS1-7SE微波栅栏是一种高效的安全防护设备,适用于各种场所和应用。以下是关于其使用的简要手册。 1. 安装前准备:在安装前,请确保具备必要的材料和工具,如栅栏控制器、微波天线、接口电缆等。同时,了解栅栏使用的环境和场所情况,以确定最佳安装位置。 2. 安装:据安装手册提供的步骤和说明,正确安装栅栏设备。确保天线正确对准需要防护的区域,并连接好相应的电缆和接口。 3. 设置操作模式:使用栅栏控制器进行系统设置。据需要选择适当的工作模式,如触发报警、监测区域等。可以通过控制器的面板或者远程控制面板进行设置。 4. 保养与维修:定期检查栅栏设备以确保其正常运行。检查电缆和接口是否完好,天线是否清洁,控制器是否正常工作。如果发现异常情况,及时进行维修或更换。 5. 报警处理:当栅栏检测到异常时,会触发报警。用户应随时保持对栅栏状态的监控,若发生报警情况,应及时采取相应措施,如通知安保人员、调查异常源等。 6. 系统升级:随着安全需求和技术的不断发展,栅栏设备可能会进行升级。及时了解最新的系统升级和功能改进,并据需要进行升级操作。 7. 注意事项:在使用栅栏设备时,应注意安全操作。避免给设备施加不必要的压力或冲击,以免影响其正常运行。另外,在使用过程中,了解当地法律法规对于栅栏设备的要求,并遵守相关规定。 以上是关于STS1-7SE微波栅栏使用的简要手册。希望以上内容能够帮助用户正确安装、设置和维护栅栏设备,提升安全防护能力。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值