力扣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;
      }
  };
相关推荐
yzs871 小时前
OLAP数据库HashJoin性能优化揭秘
数据库·算法·性能优化·哈希算法
好家伙VCC1 小时前
**发散创新:编译器优化实战——从LLVM IR到性能飞跃的奇妙旅程**
java·开发语言·python·算法
季明洵1 小时前
数据在内存中的存储
数据结构·算法·c
阿昭L1 小时前
AVL树及其计算
数据结构
weixin_458872611 小时前
东华复试OJ每日3题打卡·复盘85~87
算法
追随者永远是胜利者1 小时前
(LeetCode-Hot100)70. 爬楼梯
java·算法·leetcode·职场和发展·go
不想看见4042 小时前
Climbing Stairs 基本动态规划:一维--力扣101算法题解笔记
算法·leetcode·动态规划
陈天伟教授2 小时前
人工智能应用- 推荐算法:05.推荐算法的社会争议
算法·机器学习·推荐算法
追随者永远是胜利者2 小时前
(LeetCode-Hot100)49. 字母异位词分组
java·算法·leetcode·职场和发展·go
apcipot_rain2 小时前
原神“十盒半价”问题的兹白式建模分析
python·数学·算法·函数·数据科学·原神·数列