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

面试题目(贝壳笔试):

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

示例:

  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()方法,会复制数组得到副本,对副本的修改,不会影响原数组的值。

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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值