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;
}
相关推荐
AI视觉网奇16 小时前
blender bpy对齐物体
算法
w20180016 小时前
二年级下册语文看图写话作文:蛋壳的奇妙之旅
笔记
daanpdf16 小时前
初三中考英语作文模板万能句型及范文大全电子版
笔记
nnsix16 小时前
设计模式 - 建造者模式 笔记
笔记·设计模式·建造者模式
吃好睡好便好16 小时前
在Matlab中绘制阶梯图
开发语言·人工智能·学习·算法·机器学习·matlab
Deep-w17 小时前
【MATLAB】基于 MATLAB 的离网光伏储能微电网容量优化仿真研究
开发语言·算法·matlab
闵孚龙17 小时前
Qwen3.7-Max深度解析:智能体Agent、AI编程、MCP工作流、跨框架泛化与百炼API,一次讲透国产大模型新前沿
人工智能·算法·架构·ai编程
Jasmine_llq17 小时前
《B4261 [GESP202503 三级] 2025》
开发语言·c++·算法·条件判断算法·位运算恒等式推导·简单算术运算
简单点好不好17 小时前
工作中的工程问题: 找圆?
算法
阿Y加油吧17 小时前
两道字符串 DP 模板题复盘:最长公共子序列 & 编辑距离
leetcode