题意:





思路:

1. 贪心 我们考虑肯定是走最近的最合适

想象自己是一个黑一日游的司机:

1.如果有乘客要上车,那么就让他上,收钱!

2.如果超载了,把距目的地最远的几个乘客踢下去,退钱。

3.行驶到下一站

(摘自http://blog.sina.com.cn/s/blog_9d987af5010158ih.html

多么生动形象….

用multiset乱搞就可以了(我代码写得很丑 慎看)

2 乱想的.. 我觉得可以用最大费用流+消圈来搞 (然而并不会 (也不能证明正确性) 也很可能会T )

//By SiriusRen
#include <set>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
struct Node{int from,to,num;}node[50005];
int k,n,c,size,ans,tot=1;
struct cmp2{
bool operator ()(Node a,Node b){
return a.to<b.to;
}
};
multiset<Node,cmp2>s;
multiset<Node,cmp2>::iterator it;
bool cmp(Node a,Node b){return a.from<b.from;}
int main(){
scanf("%d%d%d",&k,&n,&c);
for(int i=1;i<=k;i++){
scanf("%d%d%d",&node[i].from,&node[i].to,&node[i].num);
}
sort(node+1,node+1+k,cmp);
for(int i=1;i<=n;i++){
while(node[tot].from==i){
if(tot>k)break;
if(node[tot].to<node[tot].from){tot++;continue;}
s.insert(node[tot]);
size+=node[tot].num;
tot++;
}
it=s.begin();
while((*it).to==i&&!s.empty()){
ans+=(*it).num;
size-=(*it).num;
s.erase(it);
it=s.begin();
}
while(size>c){
it=s.end();it--;Node jy=*it;
int temp=(*it).num;s.erase(it);
if(size-temp>c)size-=temp;
else{
jy.num=temp-(size-c);
s.insert(jy);
size=c;
}
}
}
size=0,tot=k;s.clear();
for(int i=n;i;i--){
while(node[tot].from==i){
if(tot<1)break;
if(node[tot].to>node[tot].from){tot--;continue;}
s.insert(node[tot]);
size+=node[tot].num;
tot--;
}
it=s.end();
if(!s.empty())it--;
else goto ed;
while((*it).to==i){
ans+=(*it).num;
size-=(*it).num;
s.erase(it);
it=s.end();
if(!s.empty())it--;
else break;
}
ed:while(size>c){
it=s.begin();Node jy=*it;
int temp=(*it).num;s.erase(it);
if(size-temp>c){
size-=temp;
}
else{
jy.num=temp-(size-c);
s.insert(jy);
size=c;
}
}
}
printf("%d\n",ans);
}

POJ 3038 贪心(multiset)的更多相关文章

  1. poj 3038

    http://poj.org/problem?id=3038 这个题我是在一个关于并查集的博客中找到的,结果我就觉得这个应该是个贪心,真想不出这个与并查集有什么鬼关系,看discuss里面也都是贪心, ...

  2. HDU4268 Alice and Bob(贪心+multiset)

    Problem Description Alice and Bob's game never ends. Today, they introduce a new game. In this game, ...

  3. cf1061D 贪心+multiset 好题!

    cf上的思维题真好! 本题是在模拟的基础上贪心即可:将n段时间按照左端点(右端点为第二关键字)从小到大排序,然后遍历每一个时间段. 对于每一个时间段[li,ri],先找到multiset中最靠近li但 ...

  4. POJ - 1017 贪心训练

    Packets Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 59725   Accepted: 20273 Descrip ...

  5. hdu 4268 Alice and Bob(贪心+multiset)

    题意:卡牌覆盖,每张卡牌有高(height)和宽(width).求alice的卡牌最多可以覆盖多少bob的卡牌 思路:贪心方法就是找h可以覆盖的条件下找w最大的去覆盖. #include<ios ...

  6. HDU 4268 Alice and Bob(贪心+Multiset的应用)

     题意: Alice和Bob有n个长方形,有长度和宽度,一个矩形能够覆盖还有一个矩形的条件的是,本身长度大于等于还有一个矩形,且宽度大于等于还有一个矩形.矩形不可旋转.问你Alice最多能覆盖Bo ...

  7. POJ 2376 贪心

    题意:FJ希望它的牛做一些清洁工作.有N只牛和T个时间段,每只牛可以承担一段时间内的工作.FJ希望让最小数量的牛覆盖整个T,求出其数量.若无法覆盖整个T,则输出-1. 分析:首先要注意T表示T个时间段 ...

  8. poj 1328 贪心

    /* 贪心.... 处理处每个点按照最大距离在x轴上的映射 然后我们就有了一些线段 目的是选取尽量少的点 使得每个线段内都有点出现 我们按照左端点排序 然后逐一处理 假设第一个雷达安在第一个线段的右端 ...

  9. Yogurt factory(POJ 2393 贪心 or DP)

    Yogurt factory Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8205   Accepted: 4197 De ...

随机推荐

  1. java动态导出PDF(利用itext)

    项目基于ssm框架,使用itext动态导出pdf文件: 1.引入两个jar包:itextpdf-5.5.5.jar.itext-asian-5.2.0.jar 说明: 1.itextpdf-5.5.5 ...

  2. java操作文件的创建、删除、遍历

    java操作文件的创建.删除.遍历: package test; import java.io.File; import java.io.IOException; import java.util.A ...

  3. python import windows文件路经

    import sys sys.path.append("E:\\python\\workspacepython\\PY001\\src\\testpy01") import str ...

  4. numa 和 mysql

    cpu numa结构反应的内存访问速度问题: 在多核cpu的时代引入了cpu的numa(非一致内存访问结构): NUMA引入了node的概念,每个物理CPU都被视作一个node,而每个node都有一个 ...

  5. 深入理解 sudo 与 su 之间的区别

    深入理解 sudo 与 su 之间的区别 作者: Himanshu Arora 译者: LCTT zhb127 在早前的一篇文章中,我们深入讨论了 sudo 命令的相关内容.同时,在该文章的末尾有提到 ...

  6. 使用maven安装jar到本地仓库

    mvn install:install-file "-DgroupId={安装的jar包的groupid,可以随意起名}" "-DartifactId={安装jar包的I ...

  7. socket 编程的端口和地址复用

    在linux socket网络编程中,大规模并发TCP或UDP连接时,经常会用到端口复用:   int opt = 1;   if(setsockopt(sockfd, SOL_SOCKET,SO_R ...

  8. MyBatis学习总结(10)——批量操作

    一.mybatis中的批量操作    批量操作核心就是一次传入多个数据然后进行相关操作,增删改查中掌握其中一个其他的也不成问题 1.最新在做的短信平台,要批量插入群发的短信记录: 当然批量操作还有:批 ...

  9. sql server 2000 自动收缩数据库大小

    转载.......http://mars968.blog.163.com/blog/static/7400033200941642356258/ SQLServer2000压缩日志及数据库文件     ...

  10. Codeforces 327A-Flipping Game(暴力枚举)

    A. Flipping Game time limit per test 1 second memory limit per test 256 megabytes input standard inp ...