前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >连续数组问题

连续数组问题

作者头像
用户11458826
发布2025-01-23 17:09:37
发布2025-01-23 17:09:37
3900
代码可运行
举报
文章被收录于专栏:杀马特
运行总次数:0
代码可运行

一·题目:

leetcode链接:. - 力扣(LeetCode)

二·思路:

思路:前缀和(第二种)+化0为-1+hash:

这样可以把原题中的求子数组内零,1个数相同的最长子数组长度 转为 把0改为-1,即和为零的最长子数组长度:->这样就是前缀和为sum的最最短子数组,也就是让hash表

内key存每次遍历的sum也就是前缀和,而value存它前缀和位置的下标,这样如果遍历到某个i的位置发现此区间内存在目标,则此时该区间和为sum,目标区间为0

故一定存在前缀和为sum,故往hash去找key,发现后得到它的下标进行:i-hash[sum](长度注意);

当然这里还存在两个小细节问题:1.【-1,1】->这时符合题意但是sum此刻等于0,然而hash【0】没有初始化,因此让它ret等于2,故初始化为-1.

2.每次sum都要储存吗?当然不是:如果每次都存进去,假设上一次是刚比较出ret,那么此刻sum和某个位置前缀和相等,如果存进去则hash内对应下标是sum的值就会变大,也就是原数组下标变大,这时如果后面连着有出现为0的区间此时,ret跟新的就是后面那个小的区间,而真正的最长区间应该是这两个合一起,故只要比较了max那么就不能再次跟新此时的下标了

三·代码:
代码语言:javascript
代码运行次数:0
复制
class Solution {
public:
    int findMaxLength(vector<int>& nums) {
       int ret=0,sum=0;
       unordered_map<int,int>hash;
       hash[0]=-1;
       for(int i=0;i<nums.size();i++){
        nums[i]=nums[i]==1?1:-1;//化0为-1;
         sum+=nums[i];
         if(hash.count(sum)) ret=max(ret,i-hash[sum]);
         else hash[sum]=i;
       }
  return ret;
    }
};
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-01-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一·题目:
    • 二·思路:
      • 三·代码:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档