美文网首页每日一题让前端飞Web前端之路
第4题-调整序列使其先递增后递减,求最小增加和

第4题-调整序列使其先递增后递减,求最小增加和

作者: 青天诀 | 来源:发表于2019-08-13 11:40 被阅读0次

面试题目(贝壳笔试):

给定一个数列,调整数列中的数值,使数列变成一个严格的先递增,后递减的数列(严格递增递减,是指相邻的数字不存在相等的情况,一定存在大小关系)。调整数值的时候,只能增加数值,求出满足严格递增递减数列的最小增加和。

示例:

  1. 数列 [1, 2, 8, 8, 4, 3],调整为严格递增递减数列后,最小增加和为1,此时数列变为[1, 2, 9, 8, 4, 3]。
  2. 数列[1, 4, 2, 3, 5],调整为严格递增递减数列后,最小增加和为6,此时数列变为[1, 4, 5, 6, 5]。

答案解析:

思路分析:

  1. 该题的核心思想是要把数列变为一个严格递增递减数列,所以调整后数列中最大值的位置肯定在第二个和倒数第二个位置之间(2 ~ ary.length - 1)。
  2. 假定最大值的位置,遍历数组,调整数列使其变成递增递减数列,求出增加和。
  3. 严格递增递减数列有 ary.length - 2 种情况,求出最小的增加和即可。

实现代码:

var ary = [1, 4, 2, 3, 5];
function changeAry(ary) {
    var minSum = -1;
    for (var i = 1, len = ary.length; i < len - 1; i++) {
        var sum = 0;
        var tempAry = ary.concat();
        // 递增部分
        for (var m = 0; m < i; m++) {
            if (tempAry[m] >= tempAry[m + 1]) {
                var diff = tempAry[m] - tempAry[m + 1];
                tempAry [m + 1] += diff + 1;
                sum += diff + 1;
            }
            
        }

        // 递减部分
        for (var n = len - 1; n > i; n--) {
            if (tempAry[n] >= tempAry[n - 1]) {
                var diff = tempAry[n] - tempAry[n - 1];
                tempAry[n -1] += diff + 1;
                sum += diff + 1;
            }
        }

        if(i == 1) {
            minSum = sum;
            console.log(tempAry);
            console.log(minSum);
        } else {
            if(minSum > sum) {
                minSum = sum;
                console.log(tempAry);
                console.log(minSum);
            }
        }
        tempAry = null;
    }
}
changeAry(ary);

注意:

  1. 代码中之所以要复制一份数组,是因为对数组值的改变,会影响下一次遍历。
  2. Array.concat()方法,会复制数组得到副本,对副本的修改,不会影响原数组的值。

扫一扫 下方二维码,关注我的公众号【前端名狮】,更多精彩内容陪伴你!

【前端名狮】

相关文章

  • 第4题-调整序列使其先递增后递减,求最小增加和

    面试题目(贝壳笔试): 给定一个数列,调整数列中的数值,使数列变成一个严格的先递增,后递减的数列(严格递增递减,是...

  • 求先递增后递减数组最大值的下标

    求先递增后递减数组最大值的下标 给定数组 a, 里面的元素先严格递增后严格递减, 求最大值元素的下标. 满足时间复...

  • 2018-05-17

    《算法》 摇摆序列 当有连续递增或递减的子序列时,此时一定不是摇摆序列,只能从这个连续递增或递减的子序列中取某一个...

  • 使序列递增的最小交换次数

    有两个具有相同非零长度的整数序列A和B。可以交换它们的一些元素A[i]和B[i]。 注意,两个可交换的元素在它们各...

  • 健身:背、肱二

    训练内容: 小哑铃展臂 递增,3组 窄距器械高位下拉 递增,4组 器械后拉 递减4组。...

  • php常见运算符

    运算符 运算符优先级 主要如下 递增递减 不影响布尔值递增 null 会增加递减 null 不变|| 有短路作用。

  • 组合数据类型—序列类型(str、tuple、list)2020-

    序列类型的索引体系:正向递增序号和反向递减序号 序列类型的通用操作符和函数(共12个) 操作符描述x in s如果...

  • 数组算法相关题目--Swift

    1、提莫攻击 2、 非递减数组 3、最长且连续的的递增序列

  • JavaScript操作符

    1.递增与递减操作符 前置递增和递减操作时,变量的值都是在语句被求值之前改变的 后置递增和递减操作是在包含他们的语...

  • 354. Russian Doll Envelopes

    key tips 将所有的元素按照宽度递增排序,高度递减排序。利用最长增长序列算法,每次插入一个高度递增的信封

网友评论

    本文标题:第4题-调整序列使其先递增后递减,求最小增加和

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