首页 > 其他 > 详细

[bzoj1029]建筑抢修

时间:2019-10-07 09:22:28      阅读:90      评论:0      收藏:0      [点我收藏+]

先按照d从小到大排序,遍历所有建筑i,如果能修,显然要去修的
考虑不能修,显然选择让之前所需时间最多的那个建筑不修(如果就是自己那就放弃),用堆来维护

技术分享图片
 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 struct ji{
 4     int t,d;
 5 }a[200005];
 6 priority_queue<int>q;
 7 int n,ans;
 8 long long t;
 9 bool cmp(ji x,ji y){
10     return x.d<y.d;
11 }
12 int main(){
13     scanf("%d",&n);
14     for(int i=1;i<=n;i++)scanf("%d%d",&a[i].t,&a[i].d);
15     sort(a+1,a+n+1,cmp);
16     for(int i=1;i<=n;i++)
17         if (t+a[i].t<=a[i].d){
18             ans++;
19             t+=a[i].t;
20             q.push(a[i].t);
21         }
22         else{
23             t-=max(q.top()-a[i].t,0);
24             q.push(a[i].t);
25             q.pop();
26         }
27     printf("%d",ans);
28 }
View Code

 

[bzoj1029]建筑抢修

原文:https://www.cnblogs.com/PYWBKTDA/p/11629257.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!