超市 (0x15 二叉堆)

简介: 笔记

超市


题意

超市里有 N 件商品,每件商品都有利润 p i和过期时间 d i 每天只能卖一件商品,过期商品不能再卖。


求合理安排每天卖的商品的情况下,可以得到的最大收益是多少。


思路

首先将所有商品按照过期时间非严格单调递增排序,然后遍历每一件商品。将 S 定义为已经选择要卖的商品的集合,如果将当前遍历到的商品 node[i] 加入集合后,集合的大小小于等于 node[i]的过期时间 d i那么符合继续遍历接下来的商品。否则,将当前集合中价值最小的商品移除,直到与 d i i相等为止


代码

#include<bits/stdc++.h>
// #define int long long
#define INF 0x3f3f3f3f
#define mod 1000000007
#define MOD 998244353
#define rep(i, st, ed) for (int (i) = (st); (i) <= (ed);++(i))
#define pre(i, ed, st) for (int (i) = (ed); (i) >= (st);--(i))
using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int, int> PII;
template<typename T> inline T gcd(T a, T b) { return b ? gcd(b, a % b) : a; }
template<typename T> inline T lowbit(T x) { return x & -x; }
const int N = 1e5 + 10;
int n;
struct Node {
  int p, d;
};
void solve() {
  while (scanf("%d", &n) != EOF) {
    int res = 0;
    priority_queue<Node>pq;
    for (int i = 1; i <= n; ++i) {
      int p, d; cin >> p >> d;
      if (pq.size() < d)pq.push({ p, d });
      else {
        if (pq.size() && pq.top().p < p) {
          pq.pop();
          pq.push({ p, d });
        }
      }
    }
    while (pq.size()) {
      res += pq.top().p;
      pq.pop();
    }
    cout << res << endl;
  }
}
signed main() {
  // int t; cin >> t;
  // while (t--)
  solve();
  return 0;
}


目录
相关文章
|
算法 索引
带你拿捏链表
带你拿捏链表
130 0
|
7月前
|
存储 缓存
【海贼王的数据航海】链表—双向链表
【海贼王的数据航海】链表—双向链表
33 0
|
7月前
|
存储
【海贼王的数据航海】链表—单链表
【海贼王的数据航海】链表—单链表
44 0
|
8月前
|
算法 测试技术 C#
【单调栈】LeetCode1776:车队
【单调栈】LeetCode1776:车队
|
算法 Go 索引
一个几乎全民都会的算法——二分查找
一个几乎全民都会的算法——二分查找
84 0
|
存储 C语言 C++
二叉树遍历就是这么简单(必杀)
二叉树遍历就是这么简单(必杀)
二叉树遍历就是这么简单(必杀)
牛客 买礼物(链表 线段树)
牛客 买礼物(链表 线段树)
70 0
牛客 买礼物(链表 线段树)
八旬老人彻夜难眠,竟是为了学会二叉树
什么是二叉树:一个递归的树形数据结构,每个节点最多有两个子节点;二叉树一般都是二分查找树,每个节点的值大于它左子节点的值,小于它右子节点的值
1428 0
八旬老人彻夜难眠,竟是为了学会二叉树
|
人工智能 算法
【贪心算法】买电影票
n 个人去看电影,本来每人要买一张票,但电影院推出了一个活动:一个身高为 x 的人可以和身高至少为 2x 组合,两人一共只需买一张票。现在给出全体 n个人的身高,请问总共至少要买多少电影票?以下有回答。
【贪心算法】买电影票

热门文章

最新文章

下一篇
开通oss服务