【剑斩OFFER】算法的暴力美学——连续数组

一、题目描述

二、算法原理

我们可以把数组里面的0变成-1,这样当数组前缀和0时,表示这段区域的和0和1的数量相等。

使用 hash<前缀和,数组下标>。

假设我们要计算前缀和计算到 i 点,如果我们要让 i 到前面的某个区域内和为0,那么这个区域前面要有个 sum 等于 i 点内的区域和。

特殊情况:

当 sum = 0 时,表示从下标 0 到 i 点的前缀和 0 和 1 的数量是相等的。但是 hash 里面没有保存 0,所以我们要提前往 hash 里面保存 hash[ 0 ] = -1。

当我们求到 i 点前缀和,此时为 1,那么前面 hash 保存过 1 和他的下标 2,此时我们要计算他的长度,那么怎么计算 i 点到绿色点的长度呢?当然是 i - 绿色框住点的下标:2 = 6。

假设我们绿色框住的点有两个,问题:我们要计算 i 点到哪个绿色框住的点?

答:当然是最左边哪个,因为我们要求的是最长的那个。所以只要我们的 hash 保存过 1 就吧不要再保存了。

三、代码实现

cpp 复制代码
class Solution {
public:
    int findMaxLength(vector<int>& nums) {
        unordered_map<int,int> hash;
        hash[0] = -1;
        int sum = 0,cnt = 0;

        for(int i = 0; i < nums.size();i++)
        {
            if(nums[i] == 0) nums[i] = -1;//把0变成-1
            sum += nums[i];//计算前缀和
            if(hash.count(sum)) cnt = max(cnt,i - hash[sum]);//判断最长数组
            else hash[sum] = i;//入哈希
        }
        return cnt;

    }
};
相关推荐
王老师青少年编程几秒前
信奥赛C++提高组csp-s之组合数学专题课:鸽巢原理详解及案例实践
c++·组合数学·信奥赛·抽屉原理·csp-s·提高组·鸽巢原理
寒秋花开曾相惜5 分钟前
(学习笔记)3.8 指针运算(3.8.3 嵌套的数组& 3.8.4 定长数组)
java·开发语言·笔记·学习·算法
Гений.大天才5 分钟前
2026年计算机领域的年度主题与范式转移
算法
njidf34 分钟前
C++与Qt图形开发
开发语言·c++·算法
ZoeJoy835 分钟前
算法筑基(一):排序算法——从冒泡到快排,一文掌握最经典的排序算法
数据结构·算法·排序算法
qwehjk200840 分钟前
代码动态生成技术
开发语言·c++·算法
承渊政道1 小时前
【优选算法】(实战体会位运算的逻辑思维)
数据结构·c++·笔记·学习·算法·leetcode·visual studio
Frostnova丶1 小时前
LeetCode 2573. 找出对应 LCP 矩阵的字符串
算法·leetcode·矩阵
m0_716765231 小时前
C++提高编程--STL常用容器(set/multiset、map/multimap容器)详解
java·开发语言·c++·经验分享·学习·青少年编程·visual studio
承渊政道2 小时前
【优选算法】(实战推演模拟算法的蕴含深意)
数据结构·c++·笔记·学习·算法·leetcode·排序算法