首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从数组中查找缺少的数字

从数组中查找缺少的数字
EN

Stack Overflow用户
提问于 2016-04-15 18:17:36
回答 8查看 3.7K关注 0票数 3

写了这段代码,想得到更好的方法,使用任何算法从排序或未排序的数组中查找丢失的数字。如果它是一个未排序的数组,我将排序并执行以下命令。

代码语言:javascript
复制
private static void identifyMissingValues(Integer[] ar) {

        for(int i = 0; i < (ar.length - 1); i++) {

            int next = ar[i + 1];
            int current = ar[i];
            if((next - current) > 1) {
                System.out.println("Missing Value : " + (current + 1));
            }
        }
    }

任何比这更快或更好的代码,请建议。

EN

回答 8

Stack Overflow用户

发布于 2016-04-15 18:37:27

任何比这更快或更好的代码,请建议。

no 没有这回事-如果每个元素都必须被访问,你就不能改进O(n)算法。

票数 2
EN

Stack Overflow用户

发布于 2016-04-15 19:29:17

使用BitSet而不是排序。

代码语言:javascript
复制
    int[] ar = {7, 2, 6, 8, 10, 4, 3, 2};
    int min = IntStream.of(ar).min().getAsInt();
    BitSet b = new BitSet();
    for (int i : ar)
        b.set(i - min);
    int i = 0;
    while ((i = b.nextClearBit(i + 1)) < b.length())
        System.out.println(i + min);

结果

代码语言:javascript
复制
5
9
票数 2
EN

Stack Overflow用户

发布于 2016-04-15 18:26:19

对数组进行排序需要使用O(n*log(n))

如果您将数组的所有元素添加到HashSet (O(n))运行时,然后检查0ar.length - 1 (或任何相关范围)之间的每个数字,然后检查HashSet是否包含该数字,可以做得更好。这将占用O(n)时间。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36644419

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档