Leetcode:【448. 找到所有数组中消失的数字】题解

题目

给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1, n] 内。请你找出所有在 [1, n] 范围内但没有出现在 nums 中的数字,并以数组的形式返回结果。

难度:简单

题目链接:448. 找到所有数组中消失的数字

示例1

复制代码
输入:nums = [4,3,2,7,8,2,3,1]
输出:[5,6]

示例2

复制代码
输入:nums = [1,1]
输出:[2]

解题思路:

题目意思是再在有 n 个元素的数组中,找出[1,n]中没有出现的数组,其中 n 个元素中,可能会出现重复的元素,于是 我们就可以 再次创建一个临时数组tmp(每个元素置0),存放相应的元素来取消重复的元素。然后遍历整个数组,如果元素为零,则为没有出现在nums中的数字。

代码展示

cpp 复制代码
/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
 
int* findDisappearedNumbers(int* nums, int numsSize, int* returnSize){
    int *arr = (int*)malloc(sizeof(int)*numsSize);//用于返回的数组
    int tmp[100000] = {0};
    int i = 0;
    int x = 0;
    for(i = 0;i<=numsSize;i++)
    {
        tmp[i] = 0;
    }
    for(i = 0;i<numsSize;i++)
    {
        x = nums[i]%(numsSize+1);
        tmp[x-1] = x;
    }
    i = 1;
    int count  = 0;//记录返回数组的大小
    int j = 0;
    for(i = 1;i<=numsSize;i++)
    {
        if(tmp[i-1] == 0)
        {
            arr[j++] = i;
            count++;
        }
    }
    *returnSize = count;
    return arr;
}

【解析】

这里的arr数组用于返回数组,tmp 临时数组主要用来消除重复的元素,主要思路

通过对循环每一个数组元素,对其进行取模运算,再将其放入对应的下标的数组中

但是前提是 要对 tmp数组每一个元素置0

放入对应的下标的数组中后,

++开始遍历数组,找出[1,n] 中没有出现在nums数组中的数字++

cpp 复制代码
    for(i = 1;i<=numsSize;i++)
    {
        if(tmp[i-1] == 0)
        {
            arr[j++] = i;
            count++;
        }
    }

接着就是返回 返回数组的大小和返回数组了。

cpp 复制代码
    *returnSize = count;
    return arr;
相关推荐
南境十里·墨染春水6 小时前
C++传记(面向对象)虚析构函数 纯虚函数 抽象类 final、override关键字
开发语言·c++·笔记·算法
2301_797172756 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
有为少年7 小时前
告别“唯语料论”:用合成抽象数据为大模型开智
人工智能·深度学习·神经网络·算法·机器学习·大模型·预训练
比昨天多敲两行7 小时前
C++ 二叉搜索树
开发语言·c++·算法
Season4507 小时前
C++11之正则表达式使用指南--[正则表达式介绍]|[regex的常用函数等介绍]
c++·算法·正则表达式
Tisfy8 小时前
LeetCode 2839.判断通过操作能否让字符串相等 I:if-else(两两判断)
算法·leetcode·字符串·题解
问好眼8 小时前
《算法竞赛进阶指南》0x04 二分-1.最佳牛围栏
数据结构·c++·算法·二分·信息学奥赛
会编程的土豆8 小时前
【数据结构与算法】优先队列
数据结构·算法
蓝凌y9 小时前
51单片机之外部中断
c语言·单片机·嵌入式硬件
AF_INET69 小时前
RV1126B开发板学习篇(二)v4l2+mpp编码
c语言·经验分享·音视频·视频编解码·嵌入式软件·rv1126b