力扣1488.避免洪水泛滥

力扣1488.避免洪水泛滥

  • 贪心 + 二分

    • 将所有晴天存入集合
    • 用哈希表存每次池子上一次下雨的日期
    • 当下雨并且池子满了时,二分找到上一次下雨之后最近的晴天
cpp 复制代码
  class Solution {
      unordered_map<int,int> mp;
  public:
      vector<int> avoidFlood(vector<int>& rains) {
          int n = rains.size();
          vector<int> ans(n,1);
          set<int> zero;
          for(int i=0;i<n;i++)
          {
              int r = rains[i];
              //晴天存入集合
              if(r == 0)
              {
                  zero.insert(i);
                  continue;
              }
              //下雨并且满了
              if(mp.count(r) != 0)
              {
                  //mp[r]为上一次下雨的日期 lowerbound找>mp[r]的第一个晴天日期
                  auto it = zero.lower_bound(mp[r]);
                  if(it == zero.end()) return {};
                  ans[*it] = r;
                  zero.erase(it);
              }
              //本次下雨池子和日期
              mp[r] = i;
              ans[i] = -1;
          }
          return ans;
      }
  };
相关推荐
人道领域16 分钟前
AI抢人大战:谁在收割你的红包
大数据·人工智能·算法
TracyCoder12335 分钟前
LeetCode Hot100(34/100)——98. 验证二叉搜索树
算法·leetcode
A尘埃35 分钟前
电信运营商用户分群与精准运营(K-Means聚类)
算法·kmeans·聚类
零售ERP菜鸟1 小时前
范式革命:从“信息化”到“数字化”的本质跃迁
大数据·人工智能·职场和发展·创业创新·学习方法·业界资讯
power 雀儿2 小时前
掩码(Mask)机制 结合 多头自注意力函数
算法
会叫的恐龙2 小时前
C++ 核心知识点汇总(第六日)(字符串)
c++·算法·字符串
小糯米6012 小时前
C++顺序表和vector
开发语言·c++·算法
We་ct2 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
Lionel6892 小时前
分步实现 Flutter 鸿蒙轮播图核心功能(搜索框 + 指示灯)
算法·图搜索算法
小妖6662 小时前
js 实现快速排序算法
数据结构·算法·排序算法