945-使数组唯一的最小增量

使数组唯一的最小增量

题目

给定整数数组 A,每次 move 操作将会选择任意 A[i],并将其递增 1。

返回使 A 中的每个值都是唯一的最少操作次数。

示例 1:

输入:[1,2,2]
输出:1
解释:经过一次 move 操作,数组将变为 [1, 2, 3]。

示例 2:

输入:[3,2,1,2,1,7]
输出:6
解释:经过 6 次 move 操作,数组将变为 [3, 4, 1, 2, 5, 7]。
可以看出 5 次或 5 次以下的 move 操作是不能让数组的每个值唯一的。

提示:

0 <= A.length <= 40000
0 <= A[i] < 40000

思路

简单的思路就是以空间换时间.将所有数组存入数组,然后比较后面的值即可.数组的范围有个坑.不能是40000.因为极端情况下数组可能是40000个39999,所以自增后最大值会到79999.所以需要将范围设置为80000.

当然上述的算法的时间复杂度很高.也可以进行优化.简单算法的思路是每次碰到有重复的就去后面寻找.其实不需要,如果有重复的,就先记录需要修改的个数.同时先减去需要修改的值.比如说有三个2,那么要改的值其实是3-2+4-2,也就是当碰到有重复值时先减去多余的值,后面碰到没有重复的时候再加上即可.最后需要修改的个数为0即可.

代码

简单算法

class Solution {
    public int minIncrementForUnique(int[] A) {
        //最小增量.因为题目有约定长度及大小.可以将所有数都存在数组中,
        int[] temp = new int[80000];
        for(int i = 0;i < A.length;i++){
            temp[A[i]]++;
        }
        int result = 0;
        for(int i = 0;i < temp.length;i++){
            if(temp[i] > 1){
                for(int j = i+1;j < temp.length;j++){
                    if(temp[j] == 0){
                        temp[j] = 1;
                        result+=j-i;
                        temp[i]--;
                    }
                    if(temp[i] == 1){
                        break;
                    }
                }
            }
        }
        return result;
    }
}

优化算法

class Solution {
    public int minIncrementForUnique(int[] A) {
        //最小增量.因为题目有约定长度及大小.可以将所有数都存在数组中,
        int[] temp = new int[60000];
        for(int i = 0;i < A.length;i++){
            temp[A[i]]++;
        }
        int result = 0;
        int num = 0;
        for(int i = 0;i <temp.length;i++){
            if(temp[i] > 1){
                num +=temp[i]-1;
                result -=i*(temp[i]-1);
            }else if(num > 0 && temp[i] == 0){
                num--;
                result += i;
            }
        }
        return result;
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 首页 资讯 文章 资源 小组 相亲 登录 注册 首页 最新文章 IT 职场 前端 后端 移动端 数据库 运维 其他...
    Helen_Cat阅读 3,913评论 1 10
  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 4,434评论 0 5
  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,265评论 0 4
  • 我永远相信只要永不放弃,我们还是有机会的。最后,我们还是坚信一点,这世界上只要有梦想,只要不断努力,只要不断学习,...
    魏文花阅读 653评论 0 0
  • 热点搜索词滑动统计,每隔10秒钟,统计最近60秒钟的搜索词的搜索频次,并打印出排名最靠前的3个搜索词以及出现次数 ...
    张明洋_4b13阅读 645评论 0 0