每日一题——找到消失的数字

简介: 每日一题——找到消失的数字

找到消失的数字

题目链接

思路

一个长度为n的数组中所有数据的范围在[1,n]内,题目要求我们找出在[1,n]范围内,但数组中没有出现的数字

如果可以使用额外空间,那这题就好办了。我们直接创建一个相同大小的数组,数组的每个位置代表[1,n]的每个元素,然后遍历数组计数就行。

我们这里主要讲不利用额外空间,直接在原数组原地修改的方法法。

  • 我们先来看一个长度为n,数据范围在[1,n]内,且没有数字消失的数组[1,2,3,4,5],那么,我们可以发现,可以利用这些数据的绝对值减一当作下标,使数组的每个位置都变为负数[-1,-2,-3,-4,-5]
  • 那么再进一步想,如果数组中缺少了[1,n]中的某一个元素,那么数组当中一定有一个位置的数据不会被置为负数,而这个位置的下标加一,就是我们要找的缺失的元素。
  • 注:如果某个位置已经被置为负数了,那就不要管,因为负负得正。

实现代码:

int* findDisappearedNumbers(int* nums, int numsSize, int* returnSize){
    int count = 0;  //用来记录[1,n]中出现的元素个数
    //利用出现的元素将数组的某些位置置为负数
    for(int i = 0; i < numsSize; i++)
    {
        if(nums[abs(nums[i]) - 1] > 0)
        {
            nums[abs(nums[i]) - 1] *= -1;
            count++;
        }
    }
    *returnSize = numsSize - count; //得到返回数组的大小
    int* ret = (int*)malloc(sizeof(int) * (*returnSize)); //申请内存
    count = 0;  //用来算缺失元素的个数
    //找到缺失元素
    for(int i = 0; i < numsSize; i++)
    {
        if(nums[i] > 0)
        {
            ret[count] = i + 1;
            count++;
        }
    }
    return ret; //返回结果
}
相关文章
|
人工智能 物联网 开发者
让你拥有专属且万能的AI摄影师+AI修图师——FaceChain迎来最大版本更新
自8月11日开源了第一版本证件照后,FaceChain迎来了最大版本的更新,不仅集中上线了一波非常有用的功能,在gradio界面上也做了大幅度优化
|
应用服务中间件 nginx
nginx开发(二)配置mp4文件在线播放
1: 第一步先开打nginx的文件夹遍历功能   vi /usr/local/nginx/conf/nginx.conf #编辑配置文件,在http {下面添加以下内容: autoindex on; #开启nginx目录浏览功能 autoindex_exact_size off; #文件大小...
3664 0
|
自然语言处理 PyTorch TensorFlow
Transformers 4.37 中文文档(二十二)(1)
Transformers 4.37 中文文档(二十二)
133 1
|
11月前
|
自然语言处理 Kubernetes 异构计算
推理降本与提升资源效率的实践
本课程从业务角度探讨大模型推理部署及资源利用率提升。首先分析大模型与GPU发展趋势,包括模型开源、规模增长及多模态能力增强;其次介绍高效部署大模型推理业务的步骤,涵盖业务场景选择、架构优化及显存规划;接着讲解如何通过DeepCPU-LLM框架和DeepNCCL通讯库优化推理效率;最后探讨通过KuberGPU实现细粒度GPU资源管理,提升整体资源利用率,降低推理成本。
|
XML 开发工具 Android开发
FFmpeg开发笔记(五十六)使用Media3的Exoplayer播放网络视频
ExoPlayer最初是为了解决Android早期MediaPlayer控件对网络视频兼容性差的问题而推出的。现在,Android官方已将其升级并纳入Jetpack的Media3库,使其成为音视频操作的统一引擎。新版ExoPlayer支持多种协议,解决了设备和系统碎片化问题,可在整个Android生态中一致运行。通过修改`build.gradle`文件、布局文件及Activity代码,并添加必要的权限,即可集成并使用ExoPlayer进行网络视频播放。具体步骤包括引入依赖库、配置播放界面、编写播放逻辑以及添加互联网访问权限。
973 1
FFmpeg开发笔记(五十六)使用Media3的Exoplayer播放网络视频
|
安全 Linux 数据安全/隐私保护
Linux 文件、目录和用户权限管理指南
Linux 文件、目录和用户权限管理指南
740 0
|
定位技术
|
数据可视化 定位技术
毕设(三)——nb-lot与onenet通信
毕设(三)——nb-lot与onenet通信
217 0
|
存储 NoSQL 关系型数据库
图解 Redis String 底层数据结构 SDS 与计数器实战
图解 Redis String 底层数据结构 SDS 与计数器实战
784 0
|
计算机视觉
第四章:分支结构程序设计(练习题)
第四章:分支结构程序设计(练习题)
268 0