POJ3069 POJ2586 解题报告(异曲同工的贪心算法)
【POJ 3069】(2586见下)
原题在此:http://poj.org/problem?id=3069
题目大意:
一个直线上有N个点。点i的距离是Xi。从这些点中选取若干个加上标记。要求:对于每个点,与其距离为R的范围内必有做标记的点(包括自身)。求至少标记多少点才能满足要求。
输入:N, R,以及N个点各自距原点的距离(①不一定按照顺序,故需要排序 ②可以重叠)。
输出:被标记的点的最少个数。
解题思路:
从最左边开始看,在距离为R的范围内,被标记的点一定在第一个点的右侧(或是自身)。为了使整体标记的点最少,故应当将R范围内最右边(如果没有则标记自身)的点进行标记。即尽可能的向右辐射。

同样的,对于被标记的点,其右边超出范围R的第一个点重复上述操作,直到辐射到所有的点。

代码:
#include<iostream>
#include<algorithm>
using namespace std; int main() {
int R;//范围
int N;//点的个数
int x[];//记录位置
while ()
{
cin >> R >> N;
if (R == - && N == -)//退出
break;
for (int i = ; i < N; i++)
{
cin >> x[i];
}
sort(x, x + N);//将里面的位置排序
int n = , ans = ; while (n<N)
{
int s = x[n++];//s是没有被辐射到的最左边的那个点 while (n < N&&x[n] <= s + R)
n++;//遍历到超出s的R范围的第一个点
int p = x[n - ];//p是新标记上的点 while (n < N&&x[n] <= p + R)
n++;//前往新标记的点的最远方
ans++;
}
cout << ans << endl;
} return ;
}
【POJ 2586】
原题在此:http://poj.org/problem?id=306
题目大意:
讲的是一个奇怪的公司,它每个月要不然盈利S要不然亏损d。更有意思的是这家公司的数据出现问题,只记得自己在这一年12个月里面,任何连续五个月里面总体都是亏损的(里面可能有亏损有盈利,但和是亏损)。问有可能的最大盈利额是多少(要求输出)。
输入:s,d;
输出:如果盈利输出有可能的最大盈利额,如果亏损输出 Deficit。
解题思路:
和3069一样呀,从最左边开始,每五个一组,额不过12个月只能两组单两个。这样让有亏损的月份在小组里尽量往后排,尽力向又辐射!

如上图:红越深的地方优先选定为亏损的月份,这样辐射范围最广
下面呢,就要确定有多少个亏损月份了,知道了s和d确定亏损月份数量不是难事,注意下,如果s≥4*d的时候,必然是12个月全部亏损。另外一点,当3*d<=2*s且s<4 * d的时候,刚才一直没考虑11,12月也要开始考虑了,此时11和12月必有一个为亏损月,要不然选择最后5个月就不符合题意了。
代码:
#include<iostream>
#include<algorithm>
using namespace std; int profit(int s, int d)
{
if (d > * s)
return -*d+*s;
else if ( * d > * s)
return -*d+*s;
else if ( * d > * s)
return -*d+*s;
else if ( * d > s)
return -*d+*s;
else
return -;
} int main() {
int s, d;
while (cin >> s >> d)
{
int sum = profit(s, d);
if (sum >= )
{
cout << sum << endl;
}
else {
cout << "Deficit" << endl;
}
}
return ;
}
POJ3069 POJ2586 解题报告(异曲同工的贪心算法)的更多相关文章
- 习题:codevs 2822 爱在心中 解题报告
这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...
- NOIP2012普及组 (四年后的)解题报告 -SilverN
本章施工仍未完成 现在的时间是3.17 0:28,我困得要死 本来今天(昨天?)晚上的计划是把整个四道题的题解写出来,但是到现在还没写完T4的高效算法,简直悲伤. 尝试了用floyd写T4,终于大功告 ...
- 【LeetCode】455. Assign Cookies 解题报告(Java & Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 Java解法 Python解法 日期 [LeetCo ...
- Tarjan算法求解桥和边双连通分量(附POJ 3352 Road Construction解题报告)
http://blog.csdn.net/geniusluzh/article/details/6619575 在说Tarjan算法解决桥和边双连通分量问题之前我们先来回顾一下Tarjan算法是如何 ...
- LeetCode :1.两数之和 解题报告及算法优化思路
最近开始重拾算法,在 LeetCode上刷题.顺便也记录下解题报告以及优化思路. 题目链接:1.两数之和 题意 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 ...
- LeetCode解题记录(贪心算法)(一)
1. 前言 目前得到一本不错的算法书籍,页数不多,挺符合我的需要,于是正好借这个机会来好好的系统的刷一下算法题,一来呢,是可以给部分同学提供解题思路,和一些自己的思考,二来呢,我也可以在需要复习的时候 ...
- LeetCode解题记录(贪心算法)(二)
1. 前言 由于后面还有很多题型要写,贪心算法目前可能就到此为止了,上一篇博客的地址为 LeetCode解题记录(贪心算法)(一) 下面正式开始我们的刷题之旅 2. 贪心 763. 划分字母区间(中等 ...
- 2021字节跳动校招秋招算法面试真题解题报告--leetcode206 反转链表,内含7种语言答案
206.反转链表 1.题目描述 反转一个单链表. 示例: 输入: 1->2->3->4->5->NULL输出: 5->4->3->2->1-> ...
- 2021字节跳动校招秋招算法面试真题解题报告--leetcode19 删除链表的倒数第 n 个结点,内含7种语言答案
2021字节跳动校招秋招算法面试真题解题报告--leetcode19 删除链表的倒数第 n 个结点,内含7种语言答案 1.题目描述 给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点. ...
随机推荐
- jQuery - plugin 代码模型
1.扩展 jQuery 的全局函数,主要以 $.xxx() 的形式调用 (function($) { $.myFunction = function(array) { // code } })(jQu ...
- VS2012中,C# 配置文件读取 + C#多个工程共享共有变量 + 整理using语句
(一) C# 配置文件读取 C#工程可以自动生成配置文件,以便整个工程可以使用设置的配置进行后续的处理工作. 1. 首先,右键工程文件-->Properties -->settings-- ...
- EDA技术与ASIC设计和FPGA开发有什么关系?FPGA在ASIC设计中有什么用途?
利用EDA技术进行电子系统设计的最后目标是完成专用集成电路ASIC的设计和实现:FPGA和CPLD是实现这一途径的主流器件.FPGA和CPLD通常也被称为可编程专用IC,或可编程ASIC.FPGA和C ...
- ubuntu安装packet提示重复冲突问题
今天装个zip出现: dpkg: error processing archive /var/cache/apt/archives/libc6-dev-i386_2.19-0ubuntu6.5_amd ...
- Keeping Async Methods Alive
Consider a type that will print out a message when it’s finalized, and that has a Dispose method whi ...
- javascript自学002--DOM事件
事件流:元素接收事件的顺序 1.事件冒泡:事件由最具体的元素开始接收,逐级向上传递到document元素.即从里到外. 2.事件捕获:由外到里,先接收的是document然后逐级向内,最后才到具体的元 ...
- map() 函数
map()函数 map()是 Python 内置的高阶函数,它接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到一个新的 list 并返回. 例如,对于li ...
- iOS上简单推送通知(Push Notification)的实现
iOS上简单推送通知(Push Notification)的实现 根据这篇很好的教程(http://www.raywenderlich.com/3443/apple-push-notification ...
- Android 客户端设计之环境考虑
我做过两三个android客户端应用的整体设计和部分的编码,这里仅仅谈一下设计方面的故事(此乃原创2015:11:02). 做客户端设计,首先要考虑应用所在的环境,包括三方面:1 要设计的apk是在一 ...
- Replication的犄角旮旯(八)-- 订阅与发布异构的问题
<Replication的犄角旮旯>系列导读 Replication的犄角旮旯(一)--变更订阅端表名的应用场景 Replication的犄角旮旯(二)--寻找订阅端丢失的记录 Repli ...