【bzoj2034】 2009国家集训队—最大收益
2017-01-12 19:18
323 查看
http://www.lydsy.com/JudgeOnline/problem.php?id=2034 (题目链接)
很详细了→_→
题意
n个任务,每个任务只需要一个时刻就可以完成,完成后获得${W_i}$的收益,每个任务可以在${[S_i,T_i]}$间的任一时刻完成,求最大收益。Solution
http://wenku.baidu.com/link?url=thnwVQ8xR5-fvJ2oLx1ikuEIZq7_yhaopOlpRAyE7vVztNezw7ltQtvdaEBKhQC47v65hyZX8ojvsUpzpP0fLgVGlFaywmI-X_9dWCwu8Jq很详细了→_→
代码
// bzoj2034 #include<algorithm> #include<iostream> #include<cstdlib> #include<cstring> #include<cstdio> #include<cmath> #include<queue> #define LL long long #define inf 1<<30 #define Pi acos(-1.0) #define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout); using namespace std; const int maxn=5010,maxm=25000010; int s[maxn],w[maxn],head[maxn],p[maxn],n,cnt; struct edge {int to,next;}e[maxm]; struct data {int s,t,v;}a[maxn]; bool cmp(data a,data b) { return a.v>b.v; } bool match(int i,int x) { if (x>a[i].t) return 0; if (!p[x]) {p[x]=i;return 1;} if (a[p[x]].t<a[i].t) return match(i,x+1); else if (match(p[x],x+1)) {p[x]=i;return 1;} return 0; } int main() { scanf("%d",&n); for (int i=1;i<=n;i++) scanf("%d%d%d",&a[i].s,&a[i].t,&a[i].v); sort(a+1,a+1+n,cmp); LL ans=0; for (int i=1;i<=n;i++) { if (match(i,a[i].s)) ans+=a[i].v; } printf("%lld\n",ans); return 0; }
相关文章推荐
- ABAP FORM打印转PDF/pdf 预览
- App 更换应用图标
- fdisk命令
- 5.C#:stringBuilde的特性和使用
- Hihocoder1350-Binary Watch
- Android性能优化
- windows server 2012服务器
- JS简单键盘按键秒表计时器3
- 博为峰Java技术文章 ——JavaSE Swing FlowLayout布局管理器I
- du命令
- 我的内核学习笔记13:x86平台linux系统重启流程跟踪
- NoSQL类型介绍及适用场景
- 第一天
- 在Java应用程序中使用MySql 工具使用Eclipse+Navicat+MySql
- 调试错误--“illegal statement termination”
- df命令
- Android开发之关于使用PopWindow点击外部不消失的解决实例
- java版 strcmp函数
- JS简单的鼠标按键秒表计时器2
- [小项目]-netty实现聊天功能