POJ3069(贪心+巧用优先队列)
题目传送门:http://poj.org/problem?id=3069
题目大意:一个直线上有N个点。点i的距离是Xi。从这些点中选取若干个加上标记。要求:对于每个点,与其距离为R的范围内必有做标记的点(包括自身)。求至少标记多少点才能满足要求。
题目意思就是让找最少的标记点数,很好理解,贪心嘛,由于最近正在看优先队列,突然感觉这题也能用优先队列做,就实践了一发,也过了;
话不多说上码:
CODE:
#include <bits/stdc++.h> using namespace std; int main()
{
int r, n, num, num0;
priority_queue<int, vector<int>, greater<int> > Q;//优先队列,不过多解释了
while(scanf("%d%d",&r, &n) && (r != - || n != -))
{
while(!Q.empty())
Q.pop();
for(int i = ; i < n; i++)
{
scanf("%d", &num);
Q.push(num);
}
int ans = ;//最终要输出的答案
while(Q.size() > )
{
int mid = Q.top();//此时的mid表示最左边的点
while(Q.size() > )//这层循环就是找那个要标记的点
{
if(mid + r >= Q.top())
{
num0 = Q.top();
Q.pop();
}
else
{
mid = num0;//此时mid就是要标记的那个点
break;
}
} while(Q.size() > )//这层循环呢就是找到右边界
{
if(mid + r >= Q.top())
Q.pop();
else
break;
}
ans++;
}
printf("%d\n",ans);
}
return ;
}
虽说用了优先队列,但是没有过多技术成分,个人感觉比较顺手。。。
POJ3069(贪心+巧用优先队列)的更多相关文章
- 【POJ】1862:Stripies【贪心】【优先队列】
		
Stripies Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 20456 Accepted: 9098 Descrip ...
 - Codeforces 912D Fishs ( 贪心 && 概率期望 && 优先队列 )
		
题意 : 给出一个 N * M 的网格,然后给你 K 条鱼给你放置,现有规格为 r * r 的渔网,问你如果渔网随意放置去捕捞小鱼的情况下,捕到的最大期望值是多少? 分析 : 有一个很直观的想法就是 ...
 - 洛谷 P1090合并果子【贪心】【优先队列】
		
题目描述 在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和.可 ...
 - 巧用优先队列:重载运算符在STL优先队列中的应用
		
前言 写优先队列优化dijkstra的时候,需要放进优先队列的常常有数值和编号两类,以下介绍让编号捆绑数值放入优先队列的几种方法. 由于过程比较简单,记住代码即可,下面不再讲解,只附上代码,请读者自行 ...
 - 【bzoj1029】[JSOI2007]建筑抢修  贪心+堆
		
题目描述 小刚在玩JSOI提供的一个称之为“建筑抢修”的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的入侵者.但是T部落的基地里已经有N个建筑设施受到了严重的损伤,如果不尽快修复的话,这些建 ...
 - [LeetCode]621. Task Scheduler 任务安排 题解
		
题目描述 给定一个char数组,代表CPU需要做的任务,包含A-Z,不用考虑顺序,每个任务能在1个单位完成.但是有规定一个非负整数n代表两个相同任务之间需要至少n个时间单位.球最少数量的时间单位完成所 ...
 - CF #374 (Div. 2)   D.       贪心,优先队列或set
		
1.CF #374 (Div. 2) D. Maxim and Array 2.总结:按绝对值最小贪心下去即可 3.题意:对n个数进行+x或-x的k次操作,要使操作之后的n个数乘积最小. (1)优 ...
 - hihoCoder 1309:任务分配 贪心 优先队列
		
#1309 : 任务分配 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定 N 项任务的起至时间( S1, E1 ), ( S2, E2 ), ..., ( SN, ...
 - BZOJ1029: [JSOI2007]建筑抢修[模拟 贪心 优先队列]
		
1029: [JSOI2007]建筑抢修 Time Limit: 4 Sec Memory Limit: 162 MBSubmit: 3785 Solved: 1747[Submit][Statu ...
 
随机推荐
- Flink 1.3.2 Standalone模式安装
			
一.依赖文件安装 1.1 JDK 参见博文:http://www.cnblogs.com/liugh/p/6623530.html 二.文件准备 2.1 文件名称 flink-1.3.2-bin-ha ...
 - 【Java学习笔记之三十】详解Java单例(Singleton)模式
			
概念: Java中单例模式是一种常见的设计模式,单例模式的写法有好几种,这里主要介绍三种:懒汉式单例.饿汉式单例.登记式单例. 单例模式有以下特点: 1.单例类只能有一个实例. 2.单例类必须自己创建 ...
 - Tkinter  导入安装包
			
Tkinter (capitalized) refers to versions <3.0. tkinter (all lowecase) refers to versions ≥3.0
 - Python初学——窗口视窗Tkinter
			
此篇文章是跟着沫凡小哥的视频学习的,附上学习网址:https://morvanzhou.github.io/tutorials/python-basic/ 什么是 tkinter 窗口1.1 什么是 ...
 - STL(标准模板库) 中栈(stack)的使用方法
			
STL 中栈的使用方法(stack) 基本操作: stack.push(x) 将x加入栈stack中,即入栈操作 stack.pop() 出栈操作(删除栈顶),只是出栈,没有返回值 stack.t ...
 - pyhton安装pillow问题解决
			
最近在学习Python的微信处理相关,因wxpy库中的微信客户端需要接收二维码需要安装pillow,如下 class wxpy.Bot(cache_path=None, console_qr=Fals ...
 - 使用nginx实现纯前端跨越
			
你是否厌倦了老是依赖后台去处理跨域,把握不了主动权 你是否想模仿某个app倒腾一个demo,却困于接口无法跨域 那么很幸运,接下来我将现实不依赖任何后台,随心所欲的想访问哪个域名就访问哪个! 下载ng ...
 - copy和mutableCopy都是浅拷贝!!!------你被骗了很多年
			
所有系统容器类的copy或mutableCopy方法,都是浅拷贝!!! (ps:什么是容器?比如NSArray,NSMutableArray,NSDictionary,NSMutableDiction ...
 - oracle数据块核心剖析
			
详见: http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp57 数据块(Oracle Data Blocks),本文简称为" ...
 - Java基础学习 —— 线程
			
线程: 多线程的好处:解决了在一个进程中同时执行多个任务代码的问题. 自定义线程的创建方式: 1.自定一个类继承thread类,重写thread的run方法 吧自定义线程的任务代码写在run方法内,创 ...