力扣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;
      }
  };
相关推荐
多多*3 小时前
2026年最新 测试开发工程师相关 Linux相关知识点
java·开发语言·javascript·算法·spring·java-ee·maven
数智工坊3 小时前
【数据结构-线性表】2.3 双链表-循环链表-静态链表-顺序表和链表比较
数据结构·链表
VT.馒头3 小时前
【力扣】2705. 精简对象
javascript·数据结构·算法·leetcode·职场和发展·typescript
元亓亓亓3 小时前
LeetCode热题100--136. 只出现一次的数字--简单
算法·leetcode·职场和发展
2301_763472583 小时前
实时系统下的C++编程
开发语言·c++·算法
张祥6422889043 小时前
二次型:从线性代数到测量平差的桥梁
线性代数·算法·机器学习
im_AMBER3 小时前
Leetcode 113 合并 K 个升序链表
数据结构·学习·算法·leetcode·链表
高洁013 小时前
基于物理交互的具身智能决策框架设计
算法·机器学习·数据挖掘·transformer·知识图谱
REDcker3 小时前
TCP 拥塞控制算法详解:CUBIC、BBR 及传统算法
tcp/ip·算法·php
偷吃的耗子4 小时前
[CNN算法理解]:二、卷积层(从生活实例到技术细节)
算法·cnn·生活