LeetCode算法心得——连续数组(前缀和+HashMap)

大家好,我是晴天学长,公式的巧妙化简加上hashmap的灵活应用,需要的小伙伴可以关注支持一下哦!后续会继续更新的。


1) .连续数组

给定一个二进制数组 nums , 找到含有相同数量的 0 和 1 的最长连续子数组,并返回该子数组的长度。

示例 1:

输入: nums = [0,1]
输出: 2
说明: [0, 1] 是具有相同数量 0 和 1 的最长连续子数组。

示例 2:

输入: nums = [0,1,0]
输出: 2
说明: [0, 1] (或 [1, 0]) 是具有相同数量0和1的最长连续子数组。


2) .算法思路

核心:由于以上碰1加一,碰0减一的操作,当0与1数量一致时(连续数组), 其连续数组的和为零。因此我们知道数组前面的 curcurcur 值是什么,在到达该连续数组尾部时就不会变。因此我们只需要检查哈希表中是否存在其相同的 curcurcur 值即可!(多读几遍)。

为什么在哈希表中找到了相同的 curcurcur 值则算找到了一串连续数组?

"如果这是一串连续子数组,那么cur的值,在到达该子数组尾部时(紫色箭头处),与在该子数组前一位时(绿色箭头处),是相等的" 。

为什么要在哈希表中插入{0, -1}? 这是为了辅助讨论该连续数组的起始点在 index == 0 的位置的情况,如果最长连续数组在数组的最前方,不插入{0,-1}会得到错误的答案,因此我们一定要插入该辅助键值!具体可以看看动图中的前几位数字看看{0,-1}是如何辅助我们得到答案的!


3) .算法步骤

连续数组

1.用hashmap统计每个下标 0 1 的数量

2.一段子数组的0和1的数量
s[R][1] - S[L][1] = S[R][0]-S[L][0];
S[R][1] - S[R][0] = S[L][1]-S[L][0];

3.遍历数组,找最大,所以存下标。

4.要是不存在就存下来,有就不存了,因为要找最大的子数组,肯定是L的最小,相减起来才是最大的。


4).代码示例

java 复制代码
class Solution {
    public int findMaxLength(int[] nums) {
        Map<Integer, Integer> map = new HashMap<>();
            int zero = 0;
            int one = 0;
            int maxindex = 0;
            map.put(0,-1);
            for (int i = 0; i < nums.length; i++) {
                if (nums[i] == 0) {
                    zero++;
                } else {
                    one++;
                }
                int temp = one-zero;
                if (map.containsKey(temp)) {
                    if (maxindex < Math.abs((i - map.get(temp)))) {
                        maxindex = Math.abs((i - map.get(temp)));
                    }
                }
                else {
                    //没有再存
                    map.put(temp, i);
                }
            }
            return maxindex;
    }
}

5).总结

  • HashMap的应用。
  • 存下标。

试题链接:

相关推荐
醉颜凉12 分钟前
【NOIP提高组】潜伏者
java·c语言·开发语言·c++·算法
糊涂君-Q14 分钟前
Python小白学习教程从入门到入坑------第三十一课 迭代器(语法进阶)
python·学习·程序人生·考研·职场和发展·学习方法·改行学it
lapiii35821 分钟前
图论-代码随想录刷题记录[JAVA]
java·数据结构·算法·图论
Dontla2 小时前
Rust泛型系统类型推导原理(Rust类型推导、泛型类型推导、泛型推导)为什么在某些情况必须手动添加泛型特征约束?(泛型trait约束)
开发语言·算法·rust
Ttang232 小时前
Leetcode:118. 杨辉三角——Java数学法求解
算法·leetcode
喜欢打篮球的普通人2 小时前
rust模式和匹配
java·算法·rust
java小吕布2 小时前
Java中的排序算法:探索与比较
java·后端·算法·排序算法
杜若南星2 小时前
保研考研机试攻略(满分篇):第二章——满分之路上(1)
数据结构·c++·经验分享·笔记·考研·算法·贪心算法
路遇晚风2 小时前
力扣=Mysql-3322- 英超积分榜排名 III(中等)
mysql·算法·leetcode·职场和发展