如何妙用哈希表来优化遍历查找过程?刷题感悟总结,c++实现

先上题目

题目链接:题目链接

  • 这题我最先想到的就是前缀和a,构造好了以后就遍历每一个[l,r]数组(满足题目要求的连续区间数组),奈何倒数第二个样例时间超限
  • 先给出原思路代码
cpp 复制代码
class Solution {
public:
    int subarraySum(vector<int>& nums, int k) {
        //
        vector<int> a;

        int x = 0;
        int len = nums.size();
        a.resize(len + 2, 0);
        a[1] = nums[0];
        for (int i = 2; i <= len; i++) {
            a[i] = nums[i - 1]; // 0号赋值,
            a[i] += a[i - 1];
        }
        // 核心需要优化的地方
        for (int i = 0; i <= len; i++) {
            for (int j = i + 1; j <= len; j++) {
                if (a[j] - a[i] == k)
                    x++;
            }
        }
        return x;
    }
};
  • 但是介于给出的数组中可能有正数、负数,所以同样的前缀和大小可能有好几个,可以巧妙利用哈希表的find功能(或者count功能,都是查找函数),实现O(n)一次遍历全部数字就好了
  • 代码如下,已ac,主要是把上面那份代码的"核心需要优化的部分"修改
cpp 复制代码
class Solution {
public:
    int subarraySum(vector<int>& nums, int k) {
        //
        vector<int> a;

        int x = 0;
        int len = nums.size();
        a.resize(len + 2, 0);
        a[1] = nums[0];
        //从a[1]开始存前缀和
        for (int i = 2; i <= len; i++) {
            a[i] = nums[i - 1]; // 0号赋值,
            a[i] += a[i - 1];
        }
        unordered_map<int,int> myMap;
        // 核心需要优化的地方
        for (int i = 0; i <= len; i++) {
            //目的是a[i]-a[l]==k 所以要寻找a[l]
            if(myMap.count(a[i]-k)) x+=myMap[a[i]-k];
            myMap[a[i]]++;
        }
        return x;
    }
};
  • 这个思路让我想起之前做过一道题,几乎完全一样的思路,利用哈希表


    题目链接
    实现代码:
cpp 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        unordered_map<int,int> myMap;
        vector<int> x;
        for(int i=0;i<nums.size();i++){
            //说明first是具体数值
            auto  it=myMap.find(target-nums[i]);
            if(it!=myMap.end())
            {
               x ={i,it->second};
                return x;
            }
            myMap[nums[i]]=i;
        }
        return  x;

    }
};
  • 共同点是它们都利用了哈希表(unordered_map)的特性来快速查找和存储信息,以便在遍历数组时可以高效地找到满足条件的元素或子数组。
  • 两道题都是对vector& nums, int k进行查找与操作,大家可以根据这两道题找找思路,以后碰到类似题考虑该方法~
相关推荐
郝学胜-神的一滴4 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
半桔4 小时前
【IO多路转接】高并发服务器实战:Reactor 框架与 Epoll 机制的封装与设计逻辑
linux·运维·服务器·c++·io
HABuo5 小时前
【linux文件系统】磁盘结构&文件系统详谈
linux·运维·服务器·c语言·c++·ubuntu·centos
盐焗西兰花5 小时前
鸿蒙学习实战之路-Reader Kit修改翻页方式字体大小及行间距最佳实践
学习·华为·harmonyos
我在人间贩卖青春6 小时前
C++之多重继承
c++·多重继承
颜酱6 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
QiZhang | UESTC6 小时前
学习日记day76
学习
久邦科技6 小时前
20个免费电子书下载网站,实现电子书自由(2025持续更新)
学习
m0_736919106 小时前
C++代码风格检查工具
开发语言·c++·算法
yugi9878386 小时前
基于MATLAB强化学习的单智能体与多智能体路径规划算法
算法·matlab