当前位置: 首页 > news >正文

6.每日LeetCode-数组类,找到所有数组中消失的数字

题目

448找到所有数组中消失的数字.go
给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1, n] 内。请你找出所有在 [1, n] 范围内但没有出现在 nums 中的数字,并以数组的形式返回结果。
示例 1:
输入:nums = [4,3,2,7,8,2,3,1]
输出:[5,6]
示例 2:
输入:nums = [1,1]
输出:[2]
提示:
n == nums.length
1 <= n <= 105
1 <= nums[i] <= n
进阶:你能在不使用额外空间且时间复杂度为 O(n) 的情况下解决这个问题吗? 你可以假定返回的数组不算在额外空间内。

解法

package mainimport "fmt"// 448找到所有数组中消失的数字.go
// 给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1, n] 内。请你找出所有在 [1, n] 范围内但没有出现在 nums 中的数字,并以数组的形式返回结果。
// 示例 1:
// 输入:nums = [4,3,2,7,8,2,3,1]
// 输出:[5,6]
// 示例 2:
// 输入:nums = [1,1]
// 输出:[2]
// 提示:
// n == nums.length
// 1 <= n <= 105
// 1 <= nums[i] <= n
// 进阶:你能在不使用额外空间且时间复杂度为 O(n) 的情况下解决这个问题吗? 你可以假定返回的数组不算在额外空间内。// 使用 map 非常简单,但不满足进阶
func findDisappearedNumbers1(nums []int) []int {slice := make([]int, 0)mp := make(map[int]bool, len(nums))for _, val := range nums {mp[val] = true}for i := 1; i <= len(nums); i++ {if _, ok := mp[i]; !ok {slice = append(slice, i)}}return slice
}// 1. 范围为1到n,
// 2. 将每个数-1取模, 如果按顺序就得到该值应该在的index处, 将该index处的值+n, 那么在该范围的值都应该大于n
// 3. 此时我们找出值小于n的index, 即为缺失的数字
// 时间复杂的O(n) 空间复杂度O(1)
func findDisappearedNumbers(nums []int) []int {var rst []intn := len(nums)for i := 0; i < n; i++ {idx := (nums[i] - 1) % nnums[idx] = nums[idx] + n}for i := 0; i < n; i++ {if nums[i] <= n { // 因为n也可能缺失,所以是小于等于rst = append(rst, i+1) // 该坐标值+1 就是该值, 因为是1到n,而坐标从0开始}}return rst
}func main() {nums := []int{4, 3, 2, 7, 8, 2, 3, 1}fmt.Println(findDisappearedNumbers(nums))
}

http://www.lryc.cn/news/370312.html

相关文章:

  • 【Three.js】知识梳理十:Three.js纹理贴图
  • mysql order by后跟case when
  • 数字孪生赋能的智慧园区物联网云平台建设方案(97页PPT)
  • TikTok小店运营策略
  • Docker面试整理-如何查看和管理Docker容器的日志?
  • Java从放弃到继续放弃
  • 上传文件生成聊天机器人,实现客服、办公自动化智能体 | Chatopera
  • SD3303A 大功率高亮度LED驱动芯片IC
  • 站易WordPress
  • windows下JDK1.8安装
  • 怎么修改Visual Studio Code中现在github账号
  • 戴尔R720服务器(3)组RAID
  • eNSP学习——配置高级的访问控制列表
  • oracle的bitmap索引是什么
  • 「前端+鸿蒙」鸿蒙应用开发-TS接口-特殊用途
  • Centos7系统禁用Nouveau内核驱动程序【笔记】
  • Vue 面试通杀秘籍
  • 聚焦新版综合编程能力面试考查汇总
  • [工具探索]英寸vs毫米下常见尺寸排版
  • Mimio安装
  • RawChat:优化AI对话体验,全面兼容GPT功能平台
  • 一文详解PaaS平台:机遇、挑战与新变革
  • Go每日一库之rotatelogs
  • 我的网络安全之路——一场诗意的邂逅
  • Android 中USB-HID协议实现
  • 学习AI 机器学习,深度学习需要用到的python库
  • 计算机网络 期末复习(谢希仁版本)第8章
  • abap 多线程运行demo
  • python科研做图系列之时序图的绘制——对比折线图
  • 数字信号处理:关于锁存器Latch的发现