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 个结点,并且返回链表的头结点. ...
随机推荐
- 60行以内写mvc
标题党.几天前看到一个30行写mvc的文章,东施效颦,也动手写了个60行的,功能上略微扩充一些,记录下来,后面有时间可以继续优化. mvc其实是一个观察者模式.view来监听model,所以当mode ...
- u3d avatar部件的理解
u3d中带动画的fbx文件导入的时候,就会显示一个avatar组件,这个到底干嘛的一直没能很好的理解,翻看网上的介绍,基本都是告诉你,设置humanoid类型动画时,拖拉过去之类,但是这玩意到底存储了 ...
- 原生javaScript中使用Ajax实现异步通信
AJAX本质就是在HTTP协议的基础上以异步的方式与服务器进行通信,所谓异步,就是指某段程序执行时不会阻塞其它程序执行,其表现形式为程序的执行顺序不依赖程序本身的书写顺序,相反则为同步. 以下开始简单 ...
- poj1274(匈牙利算法)
The Perfect Stall Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 22809 Accepted: 101 ...
- CAS 4.0.0RC编译环境
CAS 4.0.0RC编译环境 Eclipse Java EE IDE for Web Developers. JDK1.7,注意用JDK1.8是会出现编译错误的. Maven 在编译出现test错误 ...
- JavaScript 基础第四天
一.前言 昨天我们了解了Js的很重要的一个概念叫做函数,函数就是对于冗余和垃圾代码的一种封装机制.简单的讲就是为了能让程序更好更快的执行我们将一些重复性的代码提取,封装成一个有名字的小盒子,等到我们需 ...
- python 装饰器初步学习
第一步 简单函数 ''' 简单的函数:调用两次''' def myfunc(): print ('myfunc() called.') myfunc() myfunc() 第二步 装饰器为调用函数提供 ...
- bzoj 3718
题意:戳这里 思路:很容易发现对于一个车能否移动到最终的位置只要判断路径中得最大高度与自身高端之和是否>w即可. 那么就可以转化为逆序对得最大数问题..即对于每一辆车,判断有那些最初在他前面,而 ...
- 从RAM新建QIcon对象 / Create a QIcon from binary data
一般,QIcon是通过png或ico等图标文件来初始化的,但是如果图标资源已经在内存里了,或者一个zip压缩文件内,可以通过QPixmap作为桥梁,转换为图标. zf = zipfile.ZipFil ...
- 重启Ubuntu后Hadoop的namenode起不来的解决办法
因为Ubuntu每次重启之后都会将/tmp目录清空,而默认配置下每次hadoop name node -format总是将数据信息定位到/tmp/hadoop-${user.name}中,因此需要修改 ...