【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 解题报告(异曲同工的贪心算法)的更多相关文章

  1. 习题:codevs 2822 爱在心中 解题报告

    这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...

  2. NOIP2012普及组 (四年后的)解题报告 -SilverN

    本章施工仍未完成 现在的时间是3.17 0:28,我困得要死 本来今天(昨天?)晚上的计划是把整个四道题的题解写出来,但是到现在还没写完T4的高效算法,简直悲伤. 尝试了用floyd写T4,终于大功告 ...

  3. 【LeetCode】455. Assign Cookies 解题报告(Java & Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 Java解法 Python解法 日期 [LeetCo ...

  4. Tarjan算法求解桥和边双连通分量(附POJ 3352 Road Construction解题报告)

     http://blog.csdn.net/geniusluzh/article/details/6619575 在说Tarjan算法解决桥和边双连通分量问题之前我们先来回顾一下Tarjan算法是如何 ...

  5. LeetCode :1.两数之和 解题报告及算法优化思路

    最近开始重拾算法,在 LeetCode上刷题.顺便也记录下解题报告以及优化思路. 题目链接:1.两数之和 题意 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 ...

  6. LeetCode解题记录(贪心算法)(一)

    1. 前言 目前得到一本不错的算法书籍,页数不多,挺符合我的需要,于是正好借这个机会来好好的系统的刷一下算法题,一来呢,是可以给部分同学提供解题思路,和一些自己的思考,二来呢,我也可以在需要复习的时候 ...

  7. LeetCode解题记录(贪心算法)(二)

    1. 前言 由于后面还有很多题型要写,贪心算法目前可能就到此为止了,上一篇博客的地址为 LeetCode解题记录(贪心算法)(一) 下面正式开始我们的刷题之旅 2. 贪心 763. 划分字母区间(中等 ...

  8. 2021字节跳动校招秋招算法面试真题解题报告--leetcode206 反转链表,内含7种语言答案

    206.反转链表 1.题目描述 反转一个单链表. 示例: 输入: 1->2->3->4->5->NULL输出: 5->4->3->2->1-> ...

  9. 2021字节跳动校招秋招算法面试真题解题报告--leetcode19 删除链表的倒数第 n 个结点,内含7种语言答案

    2021字节跳动校招秋招算法面试真题解题报告--leetcode19 删除链表的倒数第 n 个结点,内含7种语言答案 1.题目描述 给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点. ...

随机推荐

  1. android.util.TypedValue.applyDimension

    先看一个例子: int size = (int)TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 3, context.getResourc ...

  2. 「2014-5-31」Z-Stack - Modification of Zigbee Device Object for better network access management

    写一份赏心悦目的工程文档,是很困难的事情.若想写得完善,不仅得用对工具(use the right tools),注重文笔,还得投入大把时间,真心是一件难度颇高的事情.但,若是真写好了,也是善莫大焉: ...

  3. shell学习

    set -x 进入调试模式,会把每一个命令实际执行的命令打印出来,也就是会把一些参数扩展后的样子打印出来. set +x 退出调试模式自定义变量:x=7,y=8echo `expr $x + $y` ...

  4. Extjs的js函数

    在Extjs内部使用函数的时候,由于我本身没有真正学过原生的js,所以对于一些函数的写法及用法很生疏,所以用起来很不方便,经常给自己弄出很多莫名其妙的bug, 比如当写了一个button,然后为其添加 ...

  5. selenium 富文本框处理

    selenium 富文本框处理, 网上有用API的解决方法1:参见:http://blog.csdn.net/xc5683/article/details/8963621 群里1位群友的解决方法2:参 ...

  6. c1ctf2016 wp

    web: 1.web萌新福利 没啥好说的,右键查看源码得key 2.you are not admin 一看题目,就想到http头修改,常见的x-forwarded-for,referer,host, ...

  7. 书TO BE READED

    Books Created Wednesday 10 August 2011 1.<你的降落伞是什么颜色> 在求职书里面,我觉得这本书是最接近于圣经的. 第一版出现大概还是上世纪70年代末 ...

  8. zabbix3.2安装graphtree3.0.4

    下载graphtree3.0.4 wget https://raw.githubusercontent.com/OneOaaS/graphtrees/master/graphtree3-0-1.pat ...

  9. 纯练手设置ip地址脚本

    #!/bin/bash IFO() { read -p "Configure $line Network card ( 'yes'or'no' )?" CDN </dev/t ...

  10. 如何编译MongoDB?

    本文将在Linux环境下编译Mongodb. 您可以选择已经编译好的版本直接使用,也可以尝试自己编译.https://www.mongodb.org/downloads#production   官方 ...