美文网首页
最小调整代价 lintcode91

最小调整代价 lintcode91

作者: 莫冰先生 | 来源:发表于2018-03-26 17:03 被阅读0次

题目

给一个整数数组,调整每个数的大小,使得相邻的两个数的差小于一个给定的整数target,调整每个数的代价为调整前后的差的绝对值,求调整代价之和最小是多少。

注意事项

你可以假设数组中每个整数都是正整数,且小于等于100。

样例

对于数组[1, 4, 2, 3]和target=1,最小的调整方案是调整为[2, 3, 2, 3],调整代价之和是2。返回2。

分析

动态规划,一个元素一个元素的调整,由于是要求相邻元素的差值,所以只和前一个相邻元素的值有关,所以只需要记录上一个调整的值就可以。
那么。dp[i][j]表示调整到第i个数时,此时,第i个数取值j,为代价和最小。
显然,假设dp[i-1][k]已知,则dp[i][j] = dp[i-1][k] + abs(j-A[i])
由于j和k都有多种可能取值,所以循环求解判断,k表示前一个数,j表示现在的数,假设j确定,那么k的取值就是在一个范围内,因为差值不能超过target。

代码

   public static int minAdjustmentCost(List<Integer> A,int target) {
       int n=A.size();
       int[][] f=new int[n+1][101];
        for (int i = 0; i <=n ; i++) {
            for (int j = 0; j <=100 ; j++) {
                f[i][j]=Integer.MAX_VALUE;
            }
        }
        for (int i = 0; i <=100 ; i++) {
            f[0][i]=0;
        }
        for (int i = 1; i <=n ; i++) {
            for (int j = 0; j <=100 ; j++) {
                if(f[i-1][j] !=Integer.MAX_VALUE){
                    for (int k = 0; k <=100 ; k++) {
                        //对于第一行让他变为0,初始化,当前的
                        if (Math.abs(j-k)<=target){
                            if(f[i][k]>f[i-1][j]+Math.abs(A.get(i-1)-k)){
                                f[i][k]=f[i-1][j]+Math.abs(A.get(i-1)-k);
                            }
                        }
                    }
                }
            }
        }
        int ans=Integer.MAX_VALUE;
        for(int i=0;i<=100;i++){
            if(f[n][i]<ans){
                ans=f[n][i];
            }
        }
        return ans;
    }

相关文章

  • 最小调整代价 lintcode91

    题目 给一个整数数组,调整每个数的大小,使得相邻的两个数的差小于一个给定的整数target,调整每个数的代价为调整...

  • LintCode 最小调整代价

    给一个整数数组,调整每个数的大小,使得相邻的两个数的差小于一个给定的整数target,调整每个数的代价为调整前后的...

  • LintCode 最小调整代价

    题目 给一个整数数组,调整每个数的大小,使得相邻的两个数的差小于一个给定的整数target,调整每个数的代价为调整...

  • 机器学习问题及分析笔记

    最小平方差代价函数 梯度下降步骤 梯度下降解决了什么问题?答:梯度下降解决代价函数某一点上最小化问题,将代价函数收...

  • 数据结构之图的最短生成树-prim算法

    基本思想 最小生成树(Minimum cost Spanning Tree) 构造连通图的最小代价生成树称为最小生...

  • 价值巨大的一句话

    做对的事情就是——当发现错了就尽快改,不管多大的代价都是最小的代价。

  • 《经济学经典语录–经济大师金言》

    NO.42 杰文斯认为经济学的目的是以最小的代价获取最大的效用。这个命题的难点在于判别何种事情存在最小代价。–《经...

  • 用梯度下降法来调整参数w和b

    我们已经学会了代价方程,其中我们知道要使得代价方程最小,我们需要尝试出一组w和b,使其达到最小。这篇文章就要介绍如...

  • 王家伟《日常用药健康课》笔记

    合理用药原则:能不吃药就不吃药,能口服就不肌注,能肌注就不输液。 是药三分毒,选药就选代价最小的那个,所谓代价最小...

  • 好句摘抄~

    改正一个错误,是需要付出代价的,但只要是改正了,不管多大的代价,其实都是最小的代价,你改的越晚,你付出的代价越大。...

网友评论

      本文标题:最小调整代价 lintcode91

      本文链接:https://www.haomeiwen.com/subject/ujjwqftx.html