力扣1124.表现良好的最长时间段

力扣1124.表现良好的最长时间段

  • 哈希表存最小的下标

    • 当s[i] > 0 那么他到头可以构成一个合法时间段
    • 否则 找到之前的 s[i] - 1 的下标:
      • 因为连续的前缀和一定只相差1
      • 若想算更小的s[i] - 2,s[i] - 3...
      • 一定会先算到s[i] - 1
      • 那么这些更小数 必然在 s[i]−1 首次出现的位置的右边
cpp 复制代码
  class Solution {
  public:
      int longestWPI(vector<int>& hours) {
          int n = hours.size();
          vector<int> s(n+1);
          for(int i=0;i<n;i++)
          {
              s[i+1] = s[i];
              s[i+1] += hours[i] > 8 ? 1 : -1;
              cout<<s[i+1]<<endl;
          }
          
          unordered_map<int,int> cnt;
          int res=0;
          for(int i=0;i<=n;i++)
          {
              if(s[i] > 0) res = max(res,i);
              if(cnt.find(s[i] - 1) != cnt.end())
                  res = max(res,i - cnt[s[i] - 1]);
              if(cnt.find(s[i]) == cnt.end())
                  cnt[s[i]] = i;
          }
          return res;
      }
  };
相关推荐
chao189844几秒前
MATLAB 实现声纹识别特征提取
人工智能·算法·matlab
zhishidi3 分钟前
推荐算法之:GBDT、GBDT LR、XGBoost详细解读与案例实现
人工智能·算法·推荐算法
货拉拉技术4 分钟前
货拉拉RAG优化实践:从原始数据到高质量知识库
数据库·算法
AKDreamer_HeXY14 分钟前
ABC434E 题解
c++·算法·图论·atcoder
罗湖老棍子14 分钟前
完全背包 vs 多重背包的优化逻辑
c++·算法·动态规划·背包
TL滕15 分钟前
从0开始学算法——第四天(题目参考答案)
数据结构·笔记·python·学习·算法
potato_may25 分钟前
C++ 发展简史与核心语法入门
开发语言·c++·算法
Liangwei Lin27 分钟前
洛谷 P1443 马的遍历
数据结构·算法
老鱼说AI28 分钟前
算法基础教学第二步:数组(超级详细原理级别讲解)
数据结构·神经网络·算法·链表
小白程序员成长日记1 小时前
2025.12.01 力扣每日一题
算法·leetcode·职场和发展