C++ | Leetcode C++题解之第525题连续数组

题目:

题解:

cpp 复制代码
class Solution {
public:
    int findMaxLength(vector<int>& nums) {
        int maxLength = 0;
        unordered_map<int, int> mp;
        int counter = 0;
        mp[counter] = -1;
        int n = nums.size();
        for (int i = 0; i < n; i++) {
            int num = nums[i];
            if (num == 1) {
                counter++;
            } else {
                counter--;
            }
            if (mp.count(counter)) {
                int prevIndex = mp[counter];
                maxLength = max(maxLength, i - prevIndex);
            } else {
                mp[counter] = i;
            }
        }
        return maxLength;
    }
};
相关推荐
iナナ26 分钟前
Java优选算法——二分查找
数据结构·算法·leetcode
浩浩乎@1 小时前
【openGLES】纹理
c++·opengles
叫我龙翔1 小时前
【设计模式】从游戏角度开始了解设计模式 --- 抽象工厂模式
c++·游戏·设计模式
青草地溪水旁1 小时前
设计模式(C++)详解—单例模式(1)
c++·单例模式
HMBBLOVEPDX2 小时前
C++(深拷贝和浅拷贝)
开发语言·c++·浅拷贝和深拷贝
UrSpecial2 小时前
Linux线程
linux·开发语言·c++
郝学胜-神的一滴2 小时前
深入浅出 C++20:新特性与实践
开发语言·c++·程序人生·算法·c++20
汉克老师3 小时前
第十四届蓝桥杯青少组C++选拔赛[2023.1.15]第二部分编程题(2 、寻宝石)
c++·蓝桥杯·蓝桥杯c++·c++蓝桥杯·蓝桥杯选拔赛
大锦终3 小时前
【Linux】进程间通信
linux·运维·服务器·c++
闪电麦坤953 小时前
C/C++项目练习:命令行记账本
开发语言·c++