1029: [JSOI2007]建筑抢修

Time Limit: 4 Sec  Memory Limit: 162 MB

题目连接

http://www.lydsy.com/JudgeOnline/problem.php?id=1029

Description

小 刚在玩JSOI提供的一个称之为“建筑抢修”的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的入侵者。但是T部落的基地里已经有N个建筑设 施受到了严重的损伤,如果不尽快修复的话,这些建筑设施将会完全毁坏。现在的情况是:T部落基地里只有一个修理工人,虽然他能瞬间到达任何一个建筑,但是 修复每个建筑都需要一定的时间。同时,修理工人修理完一个建筑才能修理下一个建筑,不能同时修理多个建筑。如果某个建筑在一段时间之内没有完全修理完毕, 这个建筑就报废了。你的任务是帮小刚合理的制订一个修理顺序,以抢修尽可能多的建筑。

Input

第一行是一个整数N,接下来N行每行两个整数T1,T2描述一个建筑:修理这个建筑需要T1秒,如果在T2秒之内还没有修理完成,这个建筑就报废了。

Output

输出一个整数S,表示最多可以抢修S个建筑。 数据范围: N<150000,T1

Sample Input

4
100 200
200 1300
1000 1250
2000 3200

Sample Output

3

HINT

题解:

首先按照结束时间进行排序

用一个大根堆,把每次可行的事情都扔进去,如果遇到一件事儿不行的时候,那么我们就把这件事情所花费的时间与大根堆的第一个进行对比

如果比他消耗时间小的话,那么必然可以替代那件事儿

证明还是挺简单的,想想就清楚了

代码:

//qscqesze
#include <cstdio>
#include <cmath>
#include <cstring>
#include <ctime> #include <iostream> #include <algorithm> #include <set> #include <vector> #include <sstream> #include <queue> #include <typeinfo> #include <fstream> #include <map> typedef long long ll; using namespace std; //freopen("D.in","r",stdin); //freopen("D.out","w",stdout); #define sspeed ios_base::sync_with_stdio(0);cin.tie(0) #define maxn 200001 #define mod 10007 #define eps 1e-9 //const int inf=0x7fffffff; //无限大 const int inf=0x3f3f3f3f; /* */ //**************************************************************************************  inline ll read() { int x=0,f=1;char ch=getchar(); while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();} while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();} return x*f; } struct node { int x,y; }; bool cmp(node a,node b) { return a.y<b.y; } node a[maxn]; priority_queue<int> q; int main() { int n; cin>>n; for(int i=0;i<n;i++) a[i].x=read(),a[i].y=read(); sort(a,a+n,cmp); int now=0; int ans=0; for(int i=0;i<n;i++) { if(now+a[i].x<=a[i].y) { ans++; now+=a[i].x; q.push(a[i].x); } else { int h=q.top(); if(a[i].x<h) { q.pop(); q.push(a[i].x); now=now+a[i].x-h; } } } cout<<ans<<endl; }

 

BZOJ 1029: [JSOI2007]建筑抢修 优先队列相关推荐

  1. BZOJ 1029: [JSOI2007]建筑抢修 堆+贪心

    1029: [JSOI2007]建筑抢修 Description 小刚在玩JSOI提供的一个称之为"建筑抢修"的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的 入侵者.但 ...

  2. BZOJ 1029: [JSOI2007]建筑抢修【贪心】

    1029: [JSOI2007]建筑抢修 Time Limit: 4 Sec Memory Limit: 162 MB Description 小刚在玩JSOI提供的一个称之为"建筑抢修&q ...

  3. BZOJ.1029.[JSOI2007]建筑抢修(贪心)

    题目链接 直接排序显然怎么都不行. 先按毁坏时间排序,优先修损坏早的,中途我们再改修的建筑. 枚举每个建筑x,如果能,就修:不能的话,从之前要修的建筑中找一个花时最大的need[top],如果need ...

  4. bz 1029: [JSOI2007]建筑抢修

    1029: [JSOI2007]建筑抢修 Time Limit: 4 Sec  Memory Limit: 162 MB Submit: 3104  Solved: 1392 [Submit][Sta ...

  5. 洛谷——P4053 [JSOI2007]建筑抢修

    P4053 [JSOI2007]建筑抢修 小刚在玩JSOI提供的一个称之为"建筑抢修"的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的入侵者.但是T部落的基地里已经有N个 ...

  6. 牛客 [JSOI2007]建筑抢修

    牛客 [JSOI2007]建筑抢修:传送门 题目描述 小刚在玩JSOI提供的一个称之为"建筑抢修"的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的入侵者.但是T部落的基地 ...

  7. P4053 [JSOI2007] 建筑抢修(反悔贪心)

    P4053 [JSOI2007] 建筑抢修https://www.luogu.com.cn/problem/P4053 #include <iostream> #include <c ...

  8. 牛客网 【每日一题】5月26日题目精讲 [JSOI2007]建筑抢修

    链接: 文章目录 题目描述 题意: 题解: 题目描述 小刚在玩JSOI提供的一个称之为"建筑抢修"的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的入侵者.但是T部落的基地 ...

  9. 刷题记录:牛客NC20154[JSOI2007]建筑抢修

    传送门:牛客 题目描述 小刚在玩JSOI提供的一个称之为"建筑抢修"的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落 的入侵者.但是T部落的基地里已经有N个建筑设施受到了严 ...

  10. Bzoj1029 [JSOI2007]建筑抢修

    Time Limit: 4 Sec  Memory Limit: 162 MB Submit: 4452  Solved: 2006 Description 小刚在玩JSOI提供的一个称之为" ...

最新文章

  1. 相关疑惑解决,java线程虚假唤醒等等问题
  2. C++类的基本学习知识
  3. sql2016是否支持linux,微软 SQL Server 支持 Linux 了,2017年 中将正式推出
  4. java、oracle对CLOB处理
  5. Spring tx:advice/
  6. Android P(3)---Android P 功能和 API
  7. 使用Seaborn和Pandas进行数据可视化
  8. ListView普通列表控件的使用
  9. 微信小游戏 - 开发工具安装 - 官方 Demo 运行
  10. 在pycharm中查看opencv版本
  11. html语言怎么插入视频,如何在HTML5网页中插入 Video(视频)
  12. 【JAVA】JSR、JCP是什么?
  13. Meraki X84+ FortiGate 100F映射内网地址到外网
  14. 浅谈对js闭包的理解
  15. java+如何画一个扇形_实现一个扇形的几种方法
  16. Python基本图形绘制
  17. 2020社会热点问题及看法_翁源县2020年食品安全宣传周正式启动!
  18. cshop是什么开发语言_ecshop后台如何设置多语言选择
  19. Assemble(王爽)——nasm 和 masm的一些简单区分
  20. 用户注册后是如何进行激活的,为什么需要激活

热门文章

  1. POJ 2635 The Embarrassed Cryptographer(JAVA)
  2. vs2008 jquery 智能提示
  3. Claris FileMaker Pro更新至19.2.1.14中文版
  4. 仿微信朋友圈图片按下效果
  5. iOS底层探索之多线程(十二)—GCD源码分析(事件源dispatch_source)
  6. document.body.scrollTop滚动失效
  7. Vue2.x全家桶WebApp
  8. 中国民生银行大数据团队的Flume实践
  9. clang命令编译c++程序时报错
  10. 1.1HashMap