前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >2021-12-19:找到所有数组中消失的数字。 给你一个含 n

2021-12-19:找到所有数组中消失的数字。 给你一个含 n

原创
作者头像
福大大架构师每日一题
发布2021-12-19 21:51:32
4370
发布2021-12-19 21:51:32
举报
文章被收录于专栏:福大大架构师每日一题

2021-12-19:找到所有数组中消失的数字。

给你一个含 n 个整数的数组 nums ,其中 numsi 在区间 1, n 内。请你找出所有在 1, n 范围内但没有出现在 nums 中的数字,并以数组的形式返回结果。

进阶:你能在不使用额外空间且时间复杂度为 O(n) 的情况下解决这个问题吗? 你可以假定返回的数组不算在额外空间内。

力扣448。

答案2021-12-19:

下标循环怼。争取i位置放i+1。

时间复杂度:O(N)。

额外空间复杂度:O(1)。

代码用golang编写。代码如下:

代码语言:txt
复制
package main

import "fmt"

func main() {
    nums := []int{4, 3, 2, 7, 8, 2, 3, 1}
    ret := findDisappearedNumbers(nums)
    fmt.Println(ret)
}

func findDisappearedNumbers(nums []int) []int {
    ans := make([]int, 0)
    if len(nums) == 0 {
        return ans
    }
    N := len(nums)
    for i := 0; i < N; i++ {
        // 从i位置出发,去玩下标循环怼
        walk(nums, i)
    }
    for i := 0; i < N; i++ {
        if nums[i] != i+1 {
            ans = append(ans, i+1)
        }
    }
    return ans
}

func walk(nums []int, i int) {
    for nums[i] != i+1 { // 不断从i发货
        nexti := nums[i] - 1
        if nums[nexti] == nexti+1 {
            break
        }
        nums[i], nums[nexti] = nums[nexti], nums[i]
    }
}

执行结果如下:

图片
图片

左神java代码

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档