leetcode 525. Contiguous Array 统计1和0数量相等的最长子数组
来源:互联网 发布:血液问题人数调查数据 编辑:程序博客网 时间:2024/06/04 20:06
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的个数之间产生联系呢?我们需要用到一个trick,遇到1就加1,遇到0,就减1,这样如果某个子数组和为0,就说明0和1的个数相等,这个想法真是太叼了,不过博主木有想出来。知道了这一点,我们用一个哈希表建立子数组之和跟结尾位置的坐标之间的映射。如果某个子数组之和在哈希表里存在了,说明当前子数组减去哈希表中存的那个子数字,得到的结果是中间一段子数组之和,必然为0,说明0和1的个数相等,我们更新结果res,
map的初始化要注意
代码如下:
#include <iostream>#include <vector>#include <map>#include <set>#include <queue>#include <stack>#include <string>#include <climits>#include <algorithm>#include <sstream>#include <functional>#include <bitset>#include <numeric>#include <cmath>using namespace std;class Solution {public: int findMaxLength(vector<int>& nums) { int res = 0, n = nums.size(), sum = 0; map<int, int> mmp{ { 0, -1 } }; for (int i = 0; i < n; ++i) { sum += (nums[i] == 1) ? 1 : -1; if (mmp.find(sum)!=mmp.end()) res = max(res, i - mmp[sum]); else mmp[sum] = i; } return res; }};
- leetcode 525. Contiguous Array 统计1和0数量相等的最长子数组
- LeetCode 525. Contiguous Array
- Leetcode 525. Contiguous Array
- [LeetCode]525. Contiguous Array
- [leetcode] 525. Contiguous Array
- [leetcode]525. Contiguous Array
- LeetCode 525. Contiguous Array
- [LeetCode] 525. Contiguous Array
- leetcode 525. Contiguous Array
- LeetCode 525. Contiguous Array
- leetcode 525.Contiguous Array
- leetcode题解-525. Contiguous Array
- 最长的0,1相等子串
- [leetCode刷题笔记]525. Contiguous Array
- [Leetcode] 525. Contiguous Array 解题报告
- [LeetCode]Contiguous Array
- LeetCode.525 Contiguous Array
- 面试题:给定一个数组,数组中只包含0和1。请找到一个最长的子序列,其中0和1的数量是相同的
- 《Spark SQL大数据实例开发》9.2 综合案例实战——电商网站搜索排名统计
- 让你看懂聚类分析
- web.xml 中的 servlet 和 servlet-mapping 标签
- httpClient入门到精通-------连接池的关闭
- kinect v2_bodyindex
- leetcode 525. Contiguous Array 统计1和0数量相等的最长子数组
- C++之cmath常用库函数一览
- 1136. A Delayed Palindrome (20)
- redis学习--下载、安装
- Tomcat中 HttpServletRequst的获取网页的几种方法比较
- 简单说一说Java的内存泄漏
- LINQ、反射和特性
- 迷宫问题
- 选择排序和插入排序