bzoj1029 [JSOI2007]建筑抢修

Posted XD-TEST

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了bzoj1029 [JSOI2007]建筑抢修相关的知识,希望对你有一定的参考价值。

  贪心,按截止时间排序,然后按截止时间从小到大枚举维修的建筑,如果之前修理建筑的总时间+当前修理时间<=截止时间,那么答案+1,否则如果之前修理过的建筑中最大的修理时间>当前建筑修理时间,那么替换掉之前修理的那座建筑。

      代码

 1 #include<cstdio>
 2 #include<queue>
 3 #include<algorithm>
 4 #define mp make_pair
 5 #define fi first
 6 #define sc second
 7 using namespace std;
 8 const int N = 2001010;
 9 priority_queue<int> Q;
10 struct g{
11     int a,b;
12 }v[N];
13 bool cmp(g u,g v)
14 {
15     if (u.b==v.b) 
16     return u.a>v.a;
17     return u.b<v.b;
18 }
19 int n,sum,i,ans;
20 int main()
21 {
22     scanf("%d",&n);
23     for (i=1;i<=n;i++)
24     scanf("%d%d",&v[i].a,&v[i].b);
25     sort(v+1,v+1+n,cmp); 
26     for (i=1;i<=n;i++)
27     {
28         //printf("%d %d\n",sum,v[i].b);
29         if (sum+v[i].a>v[i].b)
30         {
31             if ((!Q.empty())&&(Q.top()>v[i].a))
32             {
33                 sum-=Q.top();
34                 sum+=v[i].a;
35                 Q.pop();
36                 Q.push(v[i].a);
37             }
38         }
39         else
40         {
41             Q.push(v[i].a);
42             sum+=v[i].a;
43             ans++;
44         }
45     } 
46     printf("%d\n",ans);
47 }

 

以上是关于bzoj1029 [JSOI2007]建筑抢修的主要内容,如果未能解决你的问题,请参考以下文章

[BZOJ1029][JSOI2007]建筑抢修

BZOJ-1029: [JSOI2007]建筑抢修(贪心+堆优化)

BZOJ1029: [JSOI2007]建筑抢修(贪心)

BZOJ1029: [JSOI2007]建筑抢修[模拟 贪心 优先队列]

AC日记——[JSOI2007]建筑抢修 bzoj 1029

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