【LeetCode75】第五十题 无限集中的最小数字

目录

题目:

示例:

分析:

代码:


题目:

示例:

分析:

这是我们在LeetCode75里遇到的第二道设计类题目,难度比上一次的设计题目要难上一些。

题目假设我们拥有一个从1开始的无限集。

设计的这个类有两个调用函数,一个让我们将无限集中最小的数移出并返回,另一个函数让我们再将一个不在无限集里的数添加会无限集里。

那么题目有给出条件,重新加回无限集的数不会大于100,并且调用次数的总和不会超过1000次。

那么我们可以直接拿一个数组来存放1000个数字来模拟无限集,因为就算1000次调用的都是移除最小值,那么1000个数字也是刚好够移除的。

不过这仅仅是理论可行,因为直接模拟的话,是会超时的。

我们可以逆向思考一下,我们不存放存在无限集的数字,我们存放被移出无限集的数字。

并且我们使用set来存放,这样每次移除最小数的时候,我们从1开始寻找set,如果数字不在set里,那么我们就把数字加入到set里来表示这个数被我们移除了。

添加回无限集的时候就更简单了,我们直接寻找要添加的数在不在我们的set里,如果在,我们就把set里的这个数字移除来表示添加回无限集里,因为set里存放的是被移出无限集的数,这样可能有点绕,大家结合着下面的代码再捋一捋。

代码:

cpp 复制代码
class SmallestInfiniteSet {
public:
    unordered_set<int>jihe; //存放的实际上是被移出无限集的元素
    SmallestInfiniteSet() {
        
    }
    
    int popSmallest() {
        int i=1;
        while(jihe.find(i)!=jihe.end()){    //从1开始寻找没有被移出无限集的数,第一个找到的就是最小数
            i++;
        }
        jihe.insert(i); //找到之后插入set表示该数被移出无限集
        return i;
    }
    
    void addBack(int num) {
        //如果该数在set里,也就是被无限集移出了,那么我们再将其移出set表示重新加回无限集里
        if(jihe.find(num)!=jihe.end()){ 
            jihe.erase(num);
        }
    }
};
相关推荐
仟濹5 分钟前
【算法打卡day34(2026-03-30 周一)】DFS专项训练(今日算法:DFS & 记忆化搜索 & 回溯)
算法·深度优先
罗湖老棍子10 分钟前
【 例 1】区间和(信息学奥赛一本通- P1547)(基础线段树和单点修改区间查询树状数组模版)
数据结构·算法·线段树·树状数组·单点修改 区间查询
tryCbest12 分钟前
Python之Flask开发框架(第一篇) — 从安装到第一个应用
开发语言·python·flask
q54314708713 分钟前
Java进阶总结——集合
java·开发语言
啥咕啦呛16 分钟前
java打卡学习5:java基础学习
java·开发语言·学习
zhangzeyuaaa18 分钟前
Python getter/setter 正确用法详解
开发语言·python
Book思议-26 分钟前
【数据结构】栈与队列核心对比
数据结构·栈与队列对比
南境十里·墨染春水27 分钟前
C++ 笔记 深赋值 浅赋值(面向对象)
开发语言·jvm·c++·笔记
旺仔.29130 分钟前
常用算法 详解
数据结构·算法
今儿敲了吗34 分钟前
算法复盘——差分
数据结构·c++·笔记·学习·算法