优选算法——前缀和(7):连续数组

🔥近津薪荼: [个人主页] 🎬个人专栏: 《近津薪荼的算法日迹》 《Linux操作系统及网络基础知识分享》 《c++基础知识详解》 《c语言基础知识详解》 ✨不要物化,矮化,弱化,钝化自己,保持锋芒,不要停止学习 这个世界上只有两个人真正在注意着你 八岁的你,和八十岁的你, 他们此刻正在注视着你, 一个希望你 勇敢开始 ,一个希望你 不留遗憾


1.上期参考代码

cpp 复制代码
class Solution {
public:
    int subarraysDivByK(vector<int>& nums, int k) {
        vector <int>hash(k);
        hash[0%k]=1;
        int sum=0,ret=0;
        for(int i=0;i<nums.size();i++)
        {
            sum+=nums[i];
            int r=(sum%k+k)%k;
            ret+=hash[r]++;
        }
        return ret;
    }
};

2.本期知识点导图

3.本期要讲解的题目是

连续数组

要点:

  • 只有01
  • 找0和1个数相同的连续子数组
  • 返回最长的长度

4.解题

4.1 暴力解法:

暴力枚举出所有子数组,然后每个子数组再统计0和1的个数O(N3)

4.2优解

二进制数组,只有两种元素,本身就有一定的规律性,可操作性也强,典型的处理方式就是替换元素,使之具有我们想要的性质

关键思路:

本题可以把数组中的0改成-1如果子数组中0和1个数相同的话,那子数组的元素之和就是一个定值0,问题就被转化成了:求和为0的最长子数组长度

熟悉不

同我们之前做过的求和为k的子数组有相似之处又有所区别。

  • 相似之处:k=0
  • 区别:之前是统计个数,这次是统计子数组长度

整体上同之前的题目差不多

只是有几个

小细节

要处理

  1. 哈希表中存啥 :之前我们哈希表中存的是子数组的个数,我们是用数组来模拟哈希表 的现在我们要统计的是字数组的长度,哈希表中记录的应该是nums数组的元素下标
  2. 先把0换成-1
  3. 某次遍历中,如果有重复的sum符合条件,只保留第一个,因为越往后的sum,留下的子数组长度越小

如图:

  1. ret的值为i与hash[sum]的差值

  2. hash[0]有个默认值,i减去这个默认值应该等于此次遍历数组的整体长度,故hash[0]=-1,为啥这里就不赘述了

  3. 在更新ret之前需要判断,是否存在 和为0的子数组,数组无法兼顾记录下标和是否存在的功能,所以我们得使用真正的散列表:unodered_map

  4. ret取所有次遍历中的最大值

代码逻辑:

  1. 初始化散列表,sum和ret
    进入循环
  2. 替换零
  3. 维护sum
  4. 判断hash[sum]是否存在,不存在再维护散列表,存在,后边就不用了

5.嗟食

如果小编写的内容对佬有帮助,还请大佬点点三连加关注哦
佬的支持就是我前进的最大动力 ~

期待与佬的再次相遇~

相关推荐
飞Link几秒前
终结序列建模:Transformer 架构深度解析与实战指南
人工智能·python·深度学习·算法·transformer
We་ct1 分钟前
LeetCode 211. 添加与搜索单词 - 数据结构设计:字典树+DFS解法详解
开发语言·前端·数据结构·算法·leetcode·typescript·深度优先
一叶落4381 分钟前
LeetCode 202. 快乐数(C语言详解 | 三种解法 | 哈希表 + 快慢指针)
c语言·数据结构·算法·leetcode·散列表
吃着火锅x唱着歌4 分钟前
LeetCode 1190.反转每对括号间的子串
算法·leetcode·职场和发展
再难也得平6 分钟前
力扣238. 除自身以外数组的乘积(Java解法)
python·算法·leetcode
Mikowoo00710 分钟前
CPU_多线程操作图片_代码详解
算法
0 0 011 分钟前
CCF-CSP 38-2 机器人复健指南(jump)【C++】考点:BFS/DFS
开发语言·c++·算法·深度优先·宽度优先
小O的算法实验室12 分钟前
2025年IEEE TSMCS SCI1区TOP,面向异构多点动态聚合的多阶段粒子群算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
xiaoye-duck12 分钟前
《算法题讲解指南:优选算法-前缀和》--29.和为k的子数组,30.和可被k整除的子数组
c++·算法
Z9fish14 分钟前
sse 哈工大 C 语言编程练习 39
c语言·数据结构·算法