【BZOJ】1572 [Usaco2009 Open]工作安排Job

【算法】贪心

【题解】

反过来做更容易理解:http://blog.csdn.net/MintGreenTZ/article/details/52949289

一般写法:http://www.cnblogs.com/ciao-sora/p/5945638.html

http://blog.csdn.net/sunshinezff/article/details/49966035

#include<cstdio>
#include<algorithm>
#include<queue>
using namespace std;
const int maxn=100010;
struct cyc{int time,value;}a[maxn];
priority_queue<int>q;
bool cmp(cyc a,cyc b)
{return a.time>b.time;}
int n;
int main()
{
    scanf("%d",&n);
    for(int i=1;i<=n;i++)scanf("%d%d",&a[i].time,&a[i].value);
    sort(a+1,a+n+1,cmp);
    long long ans=0;int mx=a[1].time;
    for(int i=1;i<=n;i++)
     {
         for(int j=1;j<=mx-a[i].time-1&&!q.empty();j++)ans+=q.top(),q.pop();
         mx=a[i].time;
         q.push(a[i].value);
         if(i<n&&a[i+1].time==a[i].time)continue;
        ans+=q.top(),q.pop();
     }
    for(int j=1;j<=mx-0-1&&!q.empty();j++)ans+=q.top(),q.pop();
    printf("%lld",ans);
    return 0;
}

时间: 2024-10-29 10:46:38

【BZOJ】1572 [Usaco2009 Open]工作安排Job的相关文章

BZOJ 1572: [Usaco2009 Open]工作安排Job( 贪心 )

贪心... 按截止时间排序 , 然后从小到大考虑 . 假设当前考虑第 i 个任务 , 若目前已选工作数 < D_i , 那就选 i ; 否则 若已选工作中利润最小的比 P_i 小 , 那就去除它 , 并选择 i . 可以用heap ( priority_queue ) 维护 -------------------------------------------------------------------------- #include<cstdio> #include<algo

bzoj 1572: [Usaco2009 Open]工作安排Job

Description Farmer John 有太多的工作要做啊!!!!!!!!为了让农场高效运转,他必须靠他的工作赚钱,每项工作花一个单位时间. 他的工作日从0时刻开始,有1000000000个单位时间(!).在任一时刻,他都可以选择编号1~N的N(1 <= N <= 100000)项工作中的任意一项工作来完成. 因为他在每个单位时间里只能做一个工作,而每项工作又有一个截止日期,所以他很难有时间完成所有N个工作,虽然还是有可能. 对于第i个工作,有一个截止时间D_i(1 <= D_i

1572: [Usaco2009 Open]工作安排Job

1572: [Usaco2009 Open]工作安排Job Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 814  Solved: 365[Submit][Status] Description Farmer John 有太多的工作要做啊!!!!!!!!为了让农场高效运转,他必须靠他的工作赚钱,每项工作花一个单位时间. 他的工作日从0时刻开始,有1000000000个单位时间(!).在任一时刻,他都可以选择编号1~N的N(1 <= N <= 10

1572: [Usaco2009 Open]工作安排Job[贪心]

Description Farmer John 有太多的工作要做啊!!!!!!!!为了让农场高效运转,他必须靠他的工作赚钱,每项工作花一个单位时间. 他的工作日从0时刻开始,有1000000000个单位时间(!).在任一时刻,他都可以选择编号1~N的N(1 <= N <= 100000)项工作中的任意一项工作来完成. 因为他在每个单位时间里只能做一个工作,而每项工作又有一个截止日期,所以他很难有时间完成所有N个工作,虽然还是有可能. 对于第i个工作,有一个截止时间D_i(1 <= D_i

【BZOJ 2245】[SDOI2011]工作安排

Description 你的公司接到了一批订单.订单要求你的公司提供n类产品,产品被编号为1~n,其中第i类产品共需要Ci件.公司共有m名员工,员工被编号为1~m员工能够制造的产品种类有所区别.一件产品必须完整地由一名员工制造,不可以由某名员工制造一部分配件后,再转交给另外一名员工继续进行制造. 我们用一个由0和1组成的m*n的矩阵A来描述每名员工能够制造哪些产品.矩阵的行和列分别被编号为1~m和1~n,Ai,j为1表示员工i能够制造产品j,为0表示员工i不能制造产品j. 如 果公司分配了过多工

bzoj1572 [Usaco2009 Open]工作安排Job

传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1572 [题解] 这么傻逼的题会想错啊... 想到用优先队列维护了但是维护的方向想错了. 按时间排序 用优先队列维护当前p最大的当前时间个. 然后加入 如果不满就加,否则选一个扔掉.最后统计队列中的即可. # include <queue> # include <stdio.h> # include <string.h> # include <iostream

【BZOJ1572】[Usaco2009 Open]工作安排Job 贪心

贪心,一开始没读好题想错了,不能直接覆盖,如因为总时间1000000000,所以说在4的时候做3是可以的...没手写堆.. 1 #include <iostream> 2 #include <cstdio> 3 #include <queue> 4 #include <algorithm> 5 using namespace std; 6 int n; 7 struct data{long long t,v;}a[100010]; 8 long long a

【贪心】bzoj1572: [Usaco2009 Open]工作安排Job

先是没怎么理解这个贪心……然后贪心又被细节弄挂…… Description Farmer John 有太多的工作要做啊!!!!!!!!为了让农场高效运转,他必须靠他的工作赚钱,每项工作花一个单位时间. 他的工作日从0时刻开始,有1000000000个单位时间(!).在任一时刻,他都可以选择编号1~N的N(1 <= N <= 100000)项工作中的任意一项工作来完成. 因为他在每个单位时间里只能做一个工作,而每项工作又有一个截止日期,所以他很难有时间完成所有N个工作,虽然还是有可能. 对于第i

[BZOJ1572] [Usaco2009 Open]工作安排Job(贪心 + 堆)

传送门 把任务按照d排序 一次加入到堆中,如果当前放不进堆中,并且比堆中最小的大, 就从堆中弹出一个数,再把当前的数放进去 #include <queue> #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #define N 100001 #define LL long long using namespace std; int n; LL