【BZOJ1029】【JSOI2007】【建筑抢修】【贪心+堆】
Description
小刚在玩JSOI提供的一个称之为“建筑抢修”的电脑游戏:经过了一场激烈的战斗,T部落消灭了全部z部落的入侵者。可是T部落的基地里已经有N个建筑设施受到了严重的损伤,假设不尽快修复的话,这些建筑设施将会全然毁坏。如今的情况是:T部落基地里仅仅有一个修理工人,尽管他能瞬间到达不论什么一个建筑,可是修复每一个建筑都须要一定的时间。
同一时候,修理工人修理完一个建筑才干修理下一个建筑,不能同一时候修理多个建筑。假设某个建筑在一段时间之内没有全然修理完成。这个建筑就报废了。你的任务是帮小刚合理的制订一个修理顺序。以抢修尽可能多的建筑。
Input
第一行是一个整数N,接下来N行每行两个整数T1,T2描写叙述一个建筑:修理这个建筑须要T1秒。假设在T2秒之内还没有修理完毕。这个建筑就报废了。
Output
输出一个整数S。表示最多能够抢修S个建筑.N < 150,000; T1 < T2 < maxlongint
Sample Input
100 200
200 1300
1000 1250
2000 3200
Sample Output
假设是就替换。。求最大值的时候用堆优化一下就好了。。
#include<iostream>
#include<cstdio>
#include<queue>
#include<algorithm>
using namespace std;
int n,now,ans;
struct use{
int last,end;
}e[1000001];
priority_queue<int>q;
bool cmp(use a,use b){return a.end<b.end;}
int main()
{
scanf("%d",&n);
for (int i=1;i<=n;i++) scanf("%d%d",&e[i].last,&e[i].end);
sort(e+1,e+n+1,cmp);
now=0;
for (int i=1;i<=n;i++)
if (now+e[i].last<=e[i].end){ans++;q.push(e[i].last);now+=e[i].last;}
else
{
int x;
if (!q.empty())
{
x=q.top();
if (x>e[i].last&&e[i].last+now<=e[i].end+x)
{
q.pop();
now-=x-e[i].last;
q.push(e[i].last);
}
}
}
cout<<ans;
}
【BZOJ1029】【JSOI2007】【建筑抢修】【贪心+堆】的更多相关文章
- BZOJ1029:[JSOI2007]建筑抢修(贪心,堆)
		
Description 小刚在玩JSOI提供的一个称之为“建筑抢修”的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的 入侵者.但是T部落的基地里已经有N个建筑设施受到了严重的损伤,如果不尽快 ...
 - BZOJ1029: [JSOI2007]建筑抢修(贪心)
		
题目链接:BZOJ1029: [JSOI2007]建筑抢修 题解:贪心思想,按结束时间从小到大排序,选花费时间尽量短的建筑维修,用堆维护. #include<stdio.h> #inclu ...
 - 【bzoj1029】[JSOI2007]建筑抢修  贪心+堆
		
题目描述 小刚在玩JSOI提供的一个称之为“建筑抢修”的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的入侵者.但是T部落的基地里已经有N个建筑设施受到了严重的损伤,如果不尽快修复的话,这些建 ...
 - BZOJ 1029 JSOI2007 建筑抢修 贪心+堆
		
题目大意:n个建筑须要抢修.第i个建筑须要T1时间抢修.必须在T2时间之前抢修完成.求最多能抢修多少建筑 首先我们对T2排序 然后依次修理 可是这样贪心显然是不对的 比方说这组数据: 5 10 10 ...
 - [JSOI2007]建筑抢修(贪心+后悔)
		
[JSOI2007]建筑抢修(贪心+后悔) 洛谷题目传送门 吐槽 这是一道经典的贪心后悔的题目 做过贪心加后悔的题目的应该一眼可以看出来 解题思路 首先按倒塌时间T2排序,再从1枚举到n,能修就修,发 ...
 - bzoj1029: [JSOI2007]建筑抢修(堆+贪心)
		
1029: [JSOI2007]建筑抢修 题目:传送门 题解: 一道以前就做过的水题(找个水题签个到嘛...) 很明显就是一道贪心题,这里我们用一个堆来维护 具体看代码吧,很容易YY所以不讲 代码: ...
 - BZOJ1029: [JSOI2007]建筑抢修[模拟 贪心 优先队列]
		
1029: [JSOI2007]建筑抢修 Time Limit: 4 Sec Memory Limit: 162 MBSubmit: 3785 Solved: 1747[Submit][Statu ...
 - BZOJ 1029 建筑抢修  贪心+堆
		
又搞了一晚上OI,编了两道BZOJ和几道NOI题库,临走之前写两篇感想 noip越来越近了,韩大和clove爷已经开始停课虐我们了... 1029: [JSOI2007]建筑抢修 Time Limit ...
 - bzoj千题计划119:bzoj1029: [JSOI2007]建筑抢修
		
http://www.lydsy.com/JudgeOnline/problem.php?id=1029 把任务按截止时间从小到大排序 如果当前时间+当前任务耗时<=当前任务截止时间,把这个任务 ...
 - BZOJ 1029  [JSOI2007]建筑抢修 (贪心 + 优先队列)
		
1029: [JSOI2007]建筑抢修 Time Limit: 4 Sec Memory Limit: 162 MBSubmit: 5452 Solved: 2422[Submit][Statu ...
 
随机推荐
- MySQL实现递归查询
			
DROP FUNCTION IF EXISTS queryChildrenCaseInfo;CREATE FUNCTION queryChildrenCaseInfo(cId INT)RETURNS ...
 - [转]浏览器缓存详解: expires, cache-control, last-modified, etag详细说明
			
最近在对CDN进行优化,对浏览器缓存深入研究了一下,记录一下,方便后来者 画了一个草图: 每个状态的详细说明如下: 1.Last-Modified 在浏览器第一次请求某一个URL时,服务器端的返回状态 ...
 - unicode、UTF-8、UTF-16的历史
			
1:中国人民通过对 ASCII 编码的中文扩充改造,产生了 GB2312 编码,可以表示6000多个常用汉字. 2:汉字实在是太多了,包括繁体和各种字符,于是产生了 GBK 编码,它包括了 GB231 ...
 - Java冒泡,快速,插入,选择排序^_^+二分算法查找
			
这段时间在学Java,期间学到了一些排序和查找方法.特此写来和大家交流,也方便自己的日后查看与复习. 1.下边是Java的主类: public class Get { public static vo ...
 - SQL Server对数据进行删除
			
SQL Server对数据进行删除,把页面的信息从数据库删除. auto"> <tr style="background:red"> <td> ...
 - Python批量添加库搜索路径
			
被win10 给坑了,换回Win7. 重装系统后,继续使用Python,Eclipse不用重装,pydev不用重装,只需重装Python2.7.6 X64 for win即可.然后,默认已安装的Pyt ...
 - Matlab移植到Eigen用到的词条
			
同型矩阵运算满足加法交换律.结合律:并存在单位元.逆元.和0元,为同型矩阵对加法的交换环. Eigen的简单运算参考:http://blog.163.com/jiaqiang_wang/blog/st ...
 - Spring 团队开源 nohttp,尽可能不用 HTTP
			
Spring 团队开源 nohttp 项目,用以查找.替换和阻止 http:// 的使用. 项目是为了在可能使用 https:// 的情况下不使用到 http://,确保不会发生中间人攻击.Sprin ...
 - 团体程序设计天梯赛-练习集-L1-036. A乘以B
			
L1-036. A乘以B 看我没骗你吧 —— 这是一道你可以在10秒内完成的题:给定两个绝对值不超过100的整数A和B,输出A乘以B的值. 输入格式: 输入在第一行给出两个整数A和B(-100 < ...
 - loadrunner报错总结
			
1.报错 没有缓存空间可用 TCP超时释放时间?是解决刚才那个报错的? 解决方法如下 修改TcpTimedWaitDelay值为1和MaxUserPort值为65534.最后,重启! 完美 ...