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;
}
相关推荐
BothSavage8 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn8 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽10 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰1 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法