【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. (转)深度分析Linux下双网卡绑定七种模式

    现在一般的企业都会 使用双网卡接入,这样既能添加网络带宽,同时又能做相应的冗余,可以说是好处多多.而一般企业都会使用linux操作系统下自带的网卡绑定模式,当然现在 网卡产商也会出一些针对window ...

  2. MySql数据源配置

    1.tomcat的config/server.xml中将以下代码写到 </Host>前: <Context docBase="struts1" path=&quo ...

  3. Shmget 参数 0600的解释

    Shmget 参数 0600的解释 0660 百位6 -- 本用户有读写权. 十位6 -- 同组用户有读写权,个位0 -- 其它用户无读写执行权.与chmod 设法一样.

  4. thinkphp学习笔记(一)

    一.入门与安装 1.进入C:\Windows\System32\drivers\etc的hosts文件中增加127.0.0.1 www.tp5.com 即访问这个域名就相当于访问127.0.0.1 2 ...

  5. 【整理】--【KERNEL】内核定时器

    一.LINUX内核定时器是内核用来控制在未来某个时间点(基于jiffies)调度执行某个函数的一种机制,其实现位于 <linux/timer.h> 和 kernel/timer.c 文件中 ...

  6. java 并发性和多线程 -- 读感 (二 线程间通讯,共享内存的机制)

    参考文章:http://ifeve.com/java-concurrency-thread-directory/ 其中的竞态,线程安全,内存模型,线程间的通信,java ThreadLocal类小节部 ...

  7. Python札记 -- 切片赋值

    一.疑惑    今天在看<Python Cookbook>第四章Python技巧的4.7小节时,发现一段初看起来让人疑惑的代码.该小节的任务是将一个包含列表(行)的列表,转换成一个新的列表 ...

  8. 分享:根据webservice WSDL地址自动生成java调用代码及JAR包

    分享:根据webservice WSDL地址自动生成java调用代码及JAR包使用步骤:一.安装java 并配置JAVA_HOME 及 path二.安装ANT 并配置ANT_HOME三.解压WsdlT ...

  9. 在Nifi 里 把 HDFS Json 为csv 格式

    import org.apache.commons.io.IOUtilsimport java.nio.charset.*import java.text.SimpleDateFormatimport ...

  10. 可在广域网部署运行的QQ高仿版 -- GG叽叽(源码)

    前段时间看到园子里有朋友开发了QQ高仿版的程序,我也非常有兴趣,以前一直有个做即时聊天程序的梦,趁这段时间工作不是很忙,就开始动手来做这个事情.根据我以往积累下来的项目经验,实现QQ的基本功能,问题应 ...