【剑斩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;

    }
};
相关推荐
你撅嘴真丑7 小时前
第九章-数字三角形
算法
在路上看风景7 小时前
19. 成员初始化列表和初始化对象
c++
uesowys7 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
zmzb01037 小时前
C++课后习题训练记录Day98
开发语言·c++
ValhallaCoder7 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮7 小时前
AI 视觉连载1:像素
算法
念风零壹8 小时前
C++ 内存避坑指南:如何用移动语义和智能指针解决“深拷贝”与“内存泄漏”
c++
智驱力人工智能8 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥9 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风9 小时前
代码随想录第十五天
数据结构·算法·leetcode