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

    }
};
相关推荐
小雨下雨的雨10 小时前
井字棋AI机器人实现详解 - Minimax算法实战-鸿蒙PC Electron框架完成
前端·人工智能·算法·华为·electron·鸿蒙
xieliyu.12 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
一条小锦吕*13 小时前
基于Spring Boot + 数据可视化 + 协同过滤算法的推荐系统设计与实现(源码+论文+部署全讲解)
spring boot·算法·信息可视化
如竟没有火炬14 小时前
最大矩阵——单调栈
数据结构·python·线性代数·算法·leetcode·矩阵
8Qi815 小时前
LeetCode 1143 & 718:最长公共子序列 / 最长重复子数组
算法·leetcode·职场和发展·动态规划
绿算技术15 小时前
万卡推理集群存储选型分析:从核心架构到应用视角
大数据·科技·算法·架构
Qt程序员16 小时前
Linux RCU 原理与应用
linux·c++·内核·linux内核·rcu
想吃火锅100516 小时前
【leetcode】1.两数之和js版
javascript·算法·leetcode
qeen8716 小时前
【C++】类与对象之类的默认成员函数(二)
android·c语言·开发语言·c++·笔记·学习