力扣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;
      }
  };
相关推荐
naruto_lnq1 分钟前
C++中的桥接模式
开发语言·c++·算法
苦藤新鸡2 分钟前
50.腐烂的橘子
数据结构·算法
无限进步_3 分钟前
面试题 02.02. 返回倒数第 k 个节点 - 题解与详细分析
c语言·开发语言·数据结构·git·链表·github·visual studio
想进个大厂7 分钟前
代码随想录day32 动态规划01
算法·动态规划
j4455661120 分钟前
C++中的职责链模式高级应用
开发语言·c++·算法
Hello World . .22 分钟前
数据结构:栈和队列
c语言·开发语言·数据结构·vim
uesowys23 分钟前
Apache Spark算法开发指导-Decision tree classifier
算法·决策树·spark
池央31 分钟前
贪心算法-最大数
算法·贪心算法
Yvonne爱编码35 分钟前
JAVA数据结构 DAY1-集合和时空复杂度
java·数据结构·python
iAkuya38 分钟前
(leetcode)力扣100 57电话号码的字母组合(回溯)
算法·leetcode·深度优先