题解 | #牛群的优先级缓存# 哈希表和队列

牛群的优先级缓存

https://www.nowcoder.com/practice/93e9b8730aef47d68befe07af1e15552

用一个哈希表和一个队列记录当前信息,根据需求进行操作

class Solution {
  private:
    int capacity; // 容量
    unordered_map<int, int> mp;// 记录映射 cowId-priority
    queue<int> qu;// 记录当前的牛使用信息
    // 初始化缓存
    void CowCache(int capacity) {
        this->capacity = capacity;
    }
    // 返回优先级
    int getPriority(int cowId) {
        if (mp.count(cowId)) {
            // 队列已满,需要弹出最久未使用
            if (qu.size() >= capacity) {
                qu.pop();
            }
            // 新的被使用的 cowId 入队
            qu.push(cowId);
            return mp[cowId];
        } else {
            return -1;
        }
    }
    // 插入或更新优先级
    void setPriority(int cowId, int priority) {
        // 队列已满,分别在 队列 和 mp 中删去队头元素
        if (qu.size() >= capacity) {
            int del = qu.front();
            qu.pop();
            mp.erase(del);
        }
        // 更新记录
        qu.push(cowId);
        mp[cowId] = priority;
    }
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param operations string字符串vector
     * @param args int整型vector<vector<>>
     * @return int整型vector
     */
    vector<int> cowCacheOperations(vector<string>& operations,
                                   vector<vector<int> >& args) {
        vector<int> ans;
        for (int i = 0; i < operations.size(); i++) {
            if (operations[i] == "CowCache") {
                CowCache(args[i][0]);
                ans.push_back(-2);
            } else if (operations[i] == "getPriority") {
                ans.push_back(getPriority(args[i][0]));
            } else if (operations[i] == "setPriority") {
                setPriority(args[i][0], args[i][1]);
                ans.push_back(-2);
            }
        }
        return ans;
    }
};

时间复杂度:

1、初始化缓存,O(1)

2、查询优先级,查找牛ID是否存在于 unordered_map 中:O(1) 平均时间复杂度

如果队列已满,弹出队首元素:O(1)

将牛ID插入队列:O(1)

总时间复杂度为 O(1)

3、更新优先级,如果队列已满,删除队首元素并在 unordered_map 中删除相应记录:O(1)

将牛ID插入队列并更新映射:O(1)

总时间复杂度为 O(1)

4、执行所有操作,遍历 operations 列表,对每个操作调用相应方法。假设有 n 个操作,则时间复杂度为 O(n)

综上,每个操作的时间复杂度为 O(1),所有操作的总时间复杂度为 O(n)

空间复杂度:

1、mp:存储最多 capacity 个牛ID和优先级,每个牛ID和优先级占用 O(1) 空间,最多 O(capacity)

2、qu:存储最多 capacity 个牛ID,每个牛ID占用 O(1) 空间,最多 O(capacity)

3、operations 和 args:假设有 n 个操作,每个操作参数的大小固定或可忽略不计,则操作列表和参数列表的空间复杂度为 O(n)

4、ans:存储 n 个操作的结果,空间复杂度为 O(n)

综上,总空间复杂度为 O(capacity + n)

全部评论

相关推荐

要冲外企的祖国花朵很温柔:今年有签约礼盒嘛
点赞 评论 收藏
分享
joe2333:怀念以前大家拿华为当保底的日子
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务