力扣:268. 丢失的数字(Java)

目录

题目描述:

给定一个包含 [0, n] 中 n 个数的数组 nums ,找出 [0, n] 这个范围内没有出现在数组中的那个数。

示例 1:

输入:nums = [3,0,1]

输出:2

解释:n = 3,因为有 3 个数字,所以所有的数字都在范围 [0,3] 内。2 是丢失的数字,因为它没有出现在 nums 中。

示例 2:

输入:nums = [0,1]

输出:2

解释:n = 2,因为有 2 个数字,所以所有的数字都在范围 [0,2] 内。2 是丢失的数字,因为它没有出现在 nums 中。

代码实现:

java 复制代码
class Solution {
    public int missingNumber(int[] nums) {
        int n = nums.length;// 数组长度
        int[] arr = new int[n + 1];// 统计元素出现次数
        for (int i = 0; i < n; i++) {
            arr[nums[i]]++;// 以元素为下标,值加一
        }

        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == 0) {
                return i;// 出现次数为0的元素,则为丢失数字
            }
        }
        return 0;
    }
}
相关推荐
多则惑少则明1 分钟前
AI大模型实用(九)Java快速实现智能体整理(使用LangChain4j-agentic + Tool)
java·人工智能·springai·langchain4j
与遨游于天地2 分钟前
深入了解 Java `synchronized`:从对象头到锁升级、线程竞争感知
java·开发语言·c#
天天摸鱼的java工程师3 分钟前
Kafka 消息积压处理实战:百万级队列清空的优化技巧
java·后端
MobotStone7 分钟前
三步高效拆解顶刊论文
算法
CreasyChan8 分钟前
unity射线与几何检测 - “与世界的交互”
算法·游戏·3d·unity·数学基础
东东的脑洞10 分钟前
【面试突击四】JAVA基础知识-线程池与参数调优
java·面试
小股虫10 分钟前
Tair Java实操手册:从零开始的缓存中间件入门指南
java·缓存·中间件
Wyy_9527*17 分钟前
Spring三种注入方式对比
java·后端·spring
shepherd11120 分钟前
从入门到实践:玩转分布式链路追踪利器SkyWalking
java·后端·架构
leiming620 分钟前
C++ 类模板对象做函数参数
开发语言·c++·算法