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;
}
相关推荐
tjl521314_214 分钟前
01C++ 分离编译与多文件编程
前端·c++·算法
_日拱一卒6 分钟前
LeetCode:23合并K个升序链表
java·数据结构·算法·leetcode·链表·职场和发展
哆啦刘小洋8 分钟前
【LeetCode每日一题】:2033(贪心+快速排序魔改)
算法·leetcode
WolfGang00732111 分钟前
代码随想录算法训练营 Day48 | 图论 part06
算法·图论
Nice_Fold14 分钟前
Kubernetes探针机制与Deployment控制器(自用笔记)
笔记·容器·kubernetes
cheems952716 分钟前
[算法手记] 动态规划 ,二维费用限制背包问题如何处理
算法·动态规划
Chase_______23 分钟前
LeetCode 1343 题解:定长滑动窗口经典入门题,从暴力枚举到高效优化一文搞懂
算法·leetcode·职场和发展
样例过了就是过了23 分钟前
LeetCode热题100 单词拆分
c++·算法·leetcode·动态规划·哈希算法
王老师青少年编程38 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【跳跃与过河问题】:跳跳!
c++·算法·贪心·csp·信奥赛·跳跃与过河问题·跳跳
MediaTea38 分钟前
ML:决策树的基本原理与实现
人工智能·算法·决策树·机器学习·数据挖掘