码迷,mamicode.com
首页 > 其他好文 > 详细

bzoj1029

时间:2017-10-31 11:17:27      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:string   one   ace   long   oid   blog   isp   close   namespace   

堆+贪心(优先队列)

我们先按t2升序排一遍,对于每栋建筑如果可以抢修就修,如果不能就看它是否比之前最大的更优,如果更优,就替换。

技术分享
#include <stdio.h>
#include <algorithm>
#include <cstring>
#include <cmath>
#include <queue>
#include <vector>
using namespace std;
typedef long long LL;
const int maxn=150000+10;
struct hh
{
  LL a,b;
}e[maxn];
int n;
LL ans,sum;
priority_queue<LL>q;
template <class T> void read(T&x)
{
  x=0;char c=getchar();int f=0;
  while(c<0||c>9){f|=(c==-);c=getchar();}
  while(c>=0&&c<=9)x=(x<<3)+(x<<1)+(c^48),c=getchar();
  x=f?-x:x;
}
bool cmp(const hh&a,const hh&b){return a.b<b.b;}
int main()
{
  read(n);
  for(register int i=1;i<=n;i++){read(e[i].a);read(e[i].b);}
  sort(e+1,e+1+n,cmp);
  for(register int i=1;i<=n;i++)
  {
      if(sum+e[i].a<e[i].b)sum+=e[i].a,ans++,q.push(e[i].a);
      else if(e[i].a<q.top())
      {
        sum-=q.top();q.pop();
        sum+=e[i].a;q.push(e[i].a);
    }
  }
  printf("%lld",ans);
  return 0;
}
View Code

 

bzoj1029

标签:string   one   ace   long   oid   blog   isp   close   namespace   

原文地址:http://www.cnblogs.com/new-hand/p/7760039.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!