Find All Numbers Disappeared in an Array数组--力扣101算法题解笔记

11.2Find All Numbers Disappeared in an Array数组

题目描述

给定一个长度为n的数组,其中包含范围从1到n的整数,有些整数重复了很多次,有些整数没有出现。求1到n中没有出现过的整数

输入输出样例

Input :[4, 3, 2, 7, 8, 2, 3, 1]

Output:[5, 6]

题解

核心思想:用数组本身当下标,数字出现过 → 就把对应位置标记成负数;最后还是正数的位置,就是没出现过的数字!

数字 x 对应下标 x-1

出现过 → 标记为负

还是正数 → 没出现过 → 就是答案

cpp 复制代码
#include <iostream>
#include <vector>
using namespace std;

vector<int> findDisappearedNumbers(vector<int>& nums) {
        vector<int> ans;
        for (const int& num : nums) {// 用数字找它应该在的位置
                int pos = abs(num) - 1;//abs(x)=x的绝对值
                if (nums[pos] > 0) {
                        nums[pos] = -nums[pos];// 出现过 → 标记成负数
                }
        }
        for (int i = 0; i < nums.size(); ++i) {
                if (nums[i] > 0) {
                        ans.push_back(i + 1);//把正数放到数组里,就是没出现过的数
                }
        }
        return ans;
}

int main() {
        vector<int> nums = { 4, 3, 2, 7, 8, 2, 3, 1 };

        vector<int> res = findDisappearedNumbers(nums);
        int count = res.size();

        cout << "[";
        for (const int &r : res) {
                cout << r;
                count--;
                if (count) {
                        cout << ",";
                }
        }
        cout << "]" << endl;

        return 0;
}
相关推荐
月明长歌2 小时前
【码道初阶-Hot100】LeetCode 438 + 567 对照详解:一套滑动窗口模板,彻底讲透“固定长度窗口 + 计数数组 + count维护”
算法·leetcode·滑动窗口
旖-旎2 小时前
二分查找(搜索插入位置)(3)
c++·算法·二分查找·力扣·双指针
XW01059992 小时前
5-11字典合并
数据结构·python·算法
wunianor2 小时前
[算法]2026年3月14日米哈游校招算法笔试题题解
算法
Elias不吃糖2 小时前
LeetCode-44 回溯解法
算法·leetcode·职场和发展
仟濹2 小时前
【算法打卡day25(2026-03-17 周二)今日算法:「回溯算法」】1-力扣17-电话号码的字母组合 2-力扣39-组合总和 3-力扣40-组合总和II
算法·leetcode·职场和发展
Storynone2 小时前
【Day26】LeetCode:452. 用最少数量的箭引爆气球,435. 无重叠区间,763. 划分字母区间
python·算法·leetcode
月明长歌2 小时前
【码道初阶-Hot100】LeetCode 3. 无重复字符的最长子串:从错误直觉到滑动窗口,彻底讲透为什么必须判断 `map.get(c) >= left`
java·算法·leetcode·哈希算法
菜菜小狗的学习笔记2 小时前
黑马程序员java web学习笔记--项目部署(Docker)
java·笔记·学习