Leetcode算法学习日志-525 Contiguous Array

Leetcode 525 Contiguous Array

题目原文

Given a binary array, find the maximum length of a contiguous subarray with equal number of 0 and 1.

Example 1:

Input: [0,1]
Output: 2
Explanation: [0, 1] is the longest contiguous subarray with equal number of 0 and 1.

Example 2:

Input: [0,1,0]
Output: 2
Explanation: [0, 1] (or [1, 0]) is a longest contiguous subarray with equal number of 0 and 1.

Note:The length of the given binary array will not exceed 50,000.

题意分析

给一串由0和1构成的数组,求其中0,1个数相同最小数组的长度。

解法分析

当遍历到0时都看做-1,对所有的元素进行累加,如果加和为0,则说明前面整个子数组都是0,1相等的子数组,如果和不为0,则将该和作为key同相应下标放入map中,若发现加和key存在,则表明从第一次加和为key时到第二次加和为key时的元素加和为0,间隔子数组为0,1平衡数组,用两次的下标相减就能得到相应长度,与maxLen比较,取大值。C++代码如下:

class Solution {
public:
    int findMaxLength(vector<int>& nums) {
        map<int,int> myMap;
        int maxLen=0,count=0;
        int i;
        for(i=0;i<nums.size();i++){
            count+=(nums[i]==0)?-1:1;
            if(count==0)
                maxLen=i+1;
            else{
                if(myMap.find(count)==myMap.end())
                    myMap[count]=i;
                else
                    maxLen=max(maxLen,i-myMap[count]);
            }
        }
        return maxLen;
    }
};
改程序的算法复杂度为O(n)。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值