leetcode 2080. 区间内查询数字的频率

题目如下

数据范围

示例

复制代码
这题十分有意思一开始我想对每个子数组排序二分结果超时了。
转换思路:我们可以提前把每个数字出现的位置先记录下来形成集合,
然后拿着left和right利用二分查找看看left和right是不是在集合里然后做一个相减就出答案了。

通过代码

cpp 复制代码
class RangeFreqQuery {
public:
   unordered_map<int,vector<int>> map;
   //unordered_map<string,int> mapc;
    RangeFreqQuery(vector<int>& arr) {
        int n = arr.size();
        for(int i = 0;i < n;i++){
           if(map.count(arr[i]) == 1)map[arr[i]].emplace_back(i);
           else{
            map[arr[i]] = vector<int>{i};
           }
        }
    }
      int findlow(vector<int>& nums,int target) {
        int n = nums.size();
        int l = 0, r = n - 1;
        int mid;
        while (l < r) {
            mid = (l + r) / 2;
            if (nums[mid] >= target) {
                r = mid;
            } else{
                l = mid + 1;
            }
        }
        if(nums[l] < target)return -1;
     
        return l;
    }
    int findhigh(vector<int>& nums,int target) {

        int n = nums.size();
        int l = 0, r = n - 1;
        int mid;
        while (l < r) {
            mid = (l + r + 1) / 2;
            if (nums[mid] > target) {
                r = mid - 1;
            } else{
                l = mid;
            }
        }
        if(nums[l] > target)return -1;
        return l;
    }
    int query(int left, int right, int value) {
      //  string a = to_string(left) + "+" + to_string(right) + "+" + to_string(value);
      //  if(mapc.count(a) == 1)return mapc[a];
        if(map.count(value) == 0)return 0;
        vector<int>& v = map[value];
        int l = findlow(v,left);
        int r = findhigh(v,right);
        if(l != -1 && r != -1){
      //      mapc[a] = r - l + 1;
            return r - l + 1;
            }
        return 0;
    }
};

/**
 * Your RangeFreqQuery object will be instantiated and called as such:
 * RangeFreqQuery* obj = new RangeFreqQuery(arr);
 * int param_1 = obj->query(left,right,value);
 */
相关推荐
超梦dasgg9 分钟前
并查集(Union-Find)详解 + Java 完整实现
java·数据结构·算法·图搜索
Shadow(⊙o⊙)13 分钟前
Linux基础IO-1.0——open、close、read及write-深入手搓分析!
linux·运维·服务器·开发语言·c++·学习
小小de风呀19 分钟前
de风——【从零开始学C++】(九)—vector的基本使用
开发语言·c++
仍然.19 分钟前
算法题目---队列+宽搜(BFS)
算法·宽度优先
AbandonForce22 分钟前
从入门到入土:二分查找算法
数据结构·算法
L_090725 分钟前
【C++】数据结构之哈希表(散列表)
数据结构·c++·散列表
仰泳之鹅28 分钟前
【C语言】动态内存管理
c语言·数据结构·算法
心中有国也有家31 分钟前
CANN 学习新范式:cann-learning-hub 如何让昇腾入门不再「劝退」
人工智能·经验分享·笔记·学习·算法
LB211233 分钟前
C++通讯录课设(西安石油大学)
开发语言·c++·算法
AI算法沐枫33 分钟前
机器学习知识点:正则化
人工智能·pytorch·python·深度学习·神经网络·算法·机器学习