资讯专栏INFORMATION COLUMN

leetcode 448 Find All Numbers Disappeared in an Ar

MoAir / 2616人阅读

摘要:如果这个位置的值为正意味着我们还没有对这个元素进行过操作,我们将这个位置的元素的值取负。在整个遍历结束后,没有取负的值的索引,就可以对应到没有在数组出现过的值解法

题目详情
Given an array of integers where 1 ≤ a[i] ≤ n (n = size of array), some elements appear twice and others appear once.
Find all the elements of [1, n] inclusive that do not appear in this array.
Could you do it without extra space and in O(n) runtime? You may assume the returned list does not count as extra space.

题目要求,输入一个大小为n的数组,数组中包含着值为1~n的元素,有的值出现过一次,有的值出现过两次,而我们需要找到没有在数组中出现的1~n中的值,并以List形式返回这些值。
这道题额外要求了我们需要在O(n)的时间复杂度下解决这个问题,同时不使用额外空间(返回的list不算做额外空间)

Example:
Input:[4,3,2,7,8,2,3,1]
Output:[5,6]

思路

在遍历每一个值的时候,我们都找到这个值按照元素1~n顺序排序时应该在的位置。

如果这个位置的值为正(意味着我们还没有对这个元素进行过操作),我们将这个位置的元素的值取负。

在整个遍历结束后,没有取负的值的索引,就可以对应到没有在数组出现过的值

解法
    public List findDisappearedNumbers(int[] nums) {
             List res = new ArrayList();
        
        for(int num : nums){
            int val = Math.abs(num)-1;
            if(nums[val] > 0){
                nums[val] = - nums[val];
            }
        }
        for(int i =0;i 0){
                res.add(i+1);
            }
        }
        return res;   
    }

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/68386.html

相关文章

  • leetcode448. Find All Numbers Disappeared in an Ar

    摘要:题目要求假设一个长度为的整数数组,数组中的元素的值位于区间中。代码如下但是这个实现违背了的空间复杂度这里结果集不视为额外空间。如果当前元素无需进行交换,则指针右移一位。无需进行的场景是指当前元素已经出现在目标位置上了。 题目要求 Given an array of integers where 1 ≤ a[i] ≤ n (n = size of array), some element...

    blankyao 评论0 收藏0
  • [LeetCode] 448. Find All Numbers Disappeared in an

    Problem Given an array of integers where 1 ≤ a[i] ≤ n (n = size of array), some elements appear twice and others appear once. Find all the elements of [1, n] inclusive that do not appear in this array...

    X_AirDu 评论0 收藏0
  • [LeetCode] 448. Find All Numbers Disappeared in an

    Problem Given an array of integers where 1 ≤ a[i] ≤ n (n = size of array), some elements appear twice and others appear once. Find all the elements of [1, n] inclusive that do not appear in this array...

    Scorpion 评论0 收藏0
  • 448. Find All Numbers Disappeared in an Array

    摘要:题目链接一般这种类型的题要,要么给赋值成不在范围内的数,要么到对应位置。 448. Find All Numbers Disappeared in an Array 题目链接:https://leetcode.com/problems... 一般这种类型的题要in place,要么给num[i]赋值成不在范围内的数,要么swap到对应位置。 public class Solution ...

    DevWiki 评论0 收藏0
  • Leetcode PHP题解--D79 448. Find All Numbers

    摘要:题目链接题目分析给定一个到的数组,返回其中缺失的数字。思路用得出到的数字,再用和给定的数组计算差集。最终代码若觉得本文章对你有用,欢迎用爱发电资助。 D79 448. Find All Numbers Disappeared in an Array 题目链接 448. Find All Numbers Disappeared in an Array 题目分析 给定一个1到n的数组,返回...

    X1nFLY 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<