题解 | #缺失的第一个正整数#

缺失的第一个正整数

https://www.nowcoder.com/practice/50ec6a5b0e4e45348544348278cdcee5

#include <unordered_map>
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param nums int整型vector 
     * @return int整型
     */
     // 先使用 哈希来坐下 这时当然空间复杂度还没达到进阶要求
    int minNumberDisappeared(vector<int>& nums) {
        // write code here

        int n = nums.size();

        if(n==0)
        {
            return 1;
        }

        unordered_map<int, int> mp;
        int m = 0; // 记录正整数的个数
        for(int i=0; i<n; ++i)
        {
            mp[nums[i]]++;
            if(nums[i]>0)
                m++;
        }
        int ans;
        for(int i=1; i<=m; ++i)
        {
            if(!mp.count(i))
            {
                ans = i;
                break;
            }
        }

        return ans;
    }
};

自己的做法 额外使用哈希的空间

全部评论

相关推荐

03-21 08:46
已编辑
门头沟学院 C++
一个什么都不会的学生:当你有硕士学历的时候HR会说就是比本科生强
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务