算法打卡Day5_lecode_448. 找到所有数组中消失的数字

简介: 算法打卡Day5_lecode_448. 找到所有数组中消失的数字

Leetcode原题

448. 找到所有数组中消失的数字移动零

20200401134307494.png

思路

看到題目的時候,给定n个整数的数组,找出数字在区间在【1,n】不存在的数。我的第一反应是可以利用hashmap存储nums 的数。然后再判断[1,n]

范围谁不存在,直接用数组返回就好了。结果题目居然有个要求,不能使用额外的空间,且时间复杂度为O(n).


只能另辟蹊径了。


然后想到了一个办法,由于nums的数字范围都在【1,n】范围内,那么我们可以利用范围以外的数。


我们只需要去遍历获取每个元素num ,num是【1,n】范围内的数。我们只要对其-1 再对n取模得到x.。必然可以取到 【1,n】对应nums[x]值。我们只要将nums[x]修改。那么剩余没有修改到的必然就是[1,n]范围内不存在的数。具体看代码

    public List<Integer> findDisappearedNumbers(int[] nums) {
        int len =nums.length;
        for(int i=0;i<len;i++){
            int tmp= (nums[i]-1)%len;
            nums[tmp] +=len ;
        }
        List<Integer> ret = new ArrayList<Integer>();
        for (int i = 0; i <len ; i++) {
            if(nums[i]<=len){
                ret.add(i+1);
            }
        }
        return ret;
    }

提交记录

20200401134307494.png

有兴趣的老爷,还可以关注我的公众号【一起收破烂】,回复【006】获取 最新java面试资料以及简历模型120套哦~

相关文章
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
223 0
|
算法 测试技术
【算法】二分算法——寻找旋转排序数组中的最小值
【算法】二分算法——寻找旋转排序数组中的最小值
178 0
|
算法
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
282 0
|
存储 算法 Go
算法学习:数组 vs 链表
算法学习:数组 vs 链表
533 0
|
存储 人工智能 算法
C 408—《数据结构》算法题基础篇—数组(通俗易懂)
408考研——《数据结构》算法题基础篇之数组。(408算法题的入门)
941 23
|
存储 监控 算法
关于员工上网监控系统中 PHP 关联数组算法的学术解析
在当代企业管理中,员工上网监控系统是维护信息安全和提升工作效率的关键工具。PHP 中的关联数组凭借其灵活的键值对存储方式,在记录员工网络活动、管理访问规则及分析上网行为等方面发挥重要作用。通过关联数组,系统能高效记录每位员工的上网历史,设定网站访问权限,并统计不同类型的网站访问频率,帮助企业洞察员工上网模式,发现潜在问题并采取相应管理措施,从而保障信息安全和提高工作效率。
244 7
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
367 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
|
存储 算法 定位技术
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
这篇文章主要介绍了稀疏数组和队列的概念、应用实例以及如何使用数组模拟队列和环形队列的实现方法。
253 0
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
|
存储 算法 Java
深入算法基础二分查找数组
文章深入学习了二分查找算法的基础,通过实战例子详细解释了算法的逻辑流程,强调了确定合法搜索边界的重要性,并提供了Java语言的代码实现。
深入算法基础二分查找数组
|
存储 算法 调度
【数据结构与算法】详解循环队列:基于数组实现高效存储与访问
【数据结构与算法】详解循环队列:基于数组实现高效存储与访问