队列练习--------最近的请求次数(LeetCode 933)

题目:点这里

解法:

cpp 复制代码
class RecentCounter {
    queue<int> q;
public:
    RecentCounter() {
        
    }
    
    int ping(int t) {
        q.push(t);
        while(t-3000>q.front()){
            q.pop();
        }
        return q.size();
    }
};

/**
 * Your RecentCounter object will be instantiated and called as such:
 * RecentCounter* obj = new RecentCounter();
 * int param_1 = obj->ping(t);
 */

这个题目我最初并未看懂,看了老师以及评论区各位大神的题解才豁然开朗,我们要写一个类,这个类的功能很简单,就是用一个数组存储输入的值,然后用一个变量计数,每输入一次数就返回一次满足条件的个数,鉴于这个题目的特性,不满足的数出现在数组头部,而插入的数字又是从尾部,所以恰好符合队列的特性,于是这个题目利用队列我们可以有条不紊地解决,利用入队将元素存入队列,利用出队弹出不符合条件的数,返回队列的长度就是满足条件的元素个数。

我的解法挺低效的哈哈,不过这代表我懂了,并且让我知道我对顺序表的使用愈发熟练啦:

我的解法:

cpp 复制代码
class RecentCounter {
private:
    vector<int> ret;
    int cnt;
public:
    RecentCounter() {
        cnt=0;
    }
    
    int ping(int t) {
        ret.push_back(t);
        cnt=ret.size();
        for(int i=0;i<ret.size();i++){
            if(ret[i]<t-3000){
                cnt--;
            }else{
                break;
            }
        }
        return cnt;
    }
};

/**
 * Your RecentCounter object will be instantiated and called as such:
 * RecentCounter* obj = new RecentCounter();
 * int param_1 = obj->ping(t);
 */

反思

现在开始了队列部分的学习,让我有了一个体会,数据结构中的各种模型,都可以用普通的数组和变量来平替,虽然说麻烦了些,但是我还是更习惯那些基础的写法,所以现在需要树立一种意识,主动去总结归纳适合于队列或栈或链表的题目,然后有的放矢,这样才能事半功倍。

相关推荐
君义_noip4 小时前
信息学奥赛一本通 1952:【10NOIP普及组】三国游戏 | 洛谷 P1199 [NOIP 2010 普及组] 三国游戏
c++·信息学奥赛·csp-s
努力也学不会java4 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎4 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
顶点多余5 小时前
使用C/C++语言链接Mysql详解
数据库·c++·mysql
汉克老师5 小时前
GESP2026年3月认证C++四级( 第二部分判断题(1-10))
c++·指针·函数重载·文件操作·数组·gesp4级·gesp四级
khddvbe5 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
菜菜小狗的学习笔记6 小时前
剑指Offer算法题(四)链表
数据结构·算法·链表
We་ct6 小时前
LeetCode 148. 排序链表:归并排序详解
前端·数据结构·算法·leetcode·链表·typescript·排序算法
wWYy.6 小时前
STL:list
开发语言·c++
小比特_蓝光7 小时前
vector模拟实现
c++