开始就觉得有思路,结果越敲越麻烦。。。 
  题意很简单,就是说一个青蛙从0点跳到m点,最多可以跳l的长度,原有石头n个(都仅表示一个点)。但是可能跳不过去,所以你是上帝,可以随便在哪儿添加石头,你的策略是让青蛙跳过去的次数最多,但是你添加了石头后,青蛙会选择最少的次数跳过去,问青蛙跳的次数最多是多少。

  原有石头与现在的距离不大于l,就找最远的那个可以跳的石头跳过去。接下来就是主要解决现在的位置与接下来的一块石头的距离大于l的情况了。模拟:上帝开始放石头,要让青蛙一定是这次跳这块石头(在上次不能跳),并且跳最近的距离。则它前一个位置 +l+1 与现在的位置 +1的最大值就是放石头的位置。但是数据范围太大,纯模拟会超时,这时就要注意到每两次放石头后跳的距离会重复,最短的距离就是 l+1,但是这儿要特殊处理一下当某一次添加石头后,它就可以直接跳到后面原有石头上了(距离不大于l)。还有就是我的代码需要特判还没有跳出来在0的时候的情况,具体可以看代码。

代码写得很麻烦

#include<set>
#include<map>
#include<queue>
#include<stack>
#include<cmath>
#include<vector>
#include<string>
#include<cstdio>
#include<cstring>
#include<stdlib.h>
#include<iostream>
#include<algorithm>
using namespace std;
#define eps 1E-8
/*注意可能会有输出-0.000*/
#define Sgn(x) (x<-eps? -1 :x<eps? 0:1)//x为两个浮点数差的比较,注意返回整型
#define Cvs(x) (x > 0.0 ? x+eps : x-eps)//浮点数转化
#define zero(x) (((x)>0?(x):-(x))<eps)//判断是否等于0
#define mul(a,b) (a<<b)
#define dir(a,b) (a>>b)
typedef long long ll;
typedef unsigned long long ull;
const int Inf=1<<28;
const double Pi=acos(-1.0);
const int Max=200010;
int rock[Max];
int n,m,l;
int Solve()
{int manx=0,now=0,pre=0;//最大步数 现在位置 前一个位置sort(rock,rock+n);rock[n++]=m;//添加最后一个石头int ran,tmp,tmpp;for(int i=0;now<m;i++){if(i==n)i=n-1;if(rock[i]-now>l)//相差大于步数 l
        {if(i&&rock[i-1]-now<l&&rock[i-1]>now)//现在的位置最远可以跳那个原有的石头
            {manx++;pre=now;now=rock[i-1];}if(rock[i]-now>l)//现在位置与之后的第一个原有石头大于步数 l
            {ran=rock[i]-l-1;//如果运用上帝铺的石头跳到了这个位置后 可能再再跳一步或者两步就可以直接跳到原有石头tmp=(ran-now)/(l+1);//注意上帝铺的石头跳两步一定最少跳过l+1的距离if(tmp){manx+=tmp*2;tmpp=now-pre;now+=tmp*(l+1);if(tmpp)pre=now-tmpp;//相差位置不变else//特判开始pre=now-l;}manx++;//现在一定可以在跳一次if(now){tmpp=now;now=max(now+1,pre+l+1);//上帝铺的石头使这一次可以跳到的最近距离pre=tmpp;}else//特判开始now=1;if(now+l>=rock[i]);//一步跳入与原有石头距离不大于步数 l,就可以跳到现在这个原有石头后者之后的原有石头else//要再铺一个石头
                {manx++;tmpp=now;now=max(now+1,pre+l+1);pre=tmpp;}}}if(rock[i]-now==l)//可能是上一个if遗留的
        {pre=now;now+=l;manx++;}if(i==n-1&&rock[i]-now<l&&rock[i]>now){manx++;return manx;}}return manx;
}
int main()
{int t,coun=0;scanf("%d",&t);while(t--){scanf("%d %d %d",&n,&m,&l);for(int i=0; i<n; i++)scanf("%d",&rock[i]);printf("Case #%d: %d\n",++coun,Solve());}return 0;
}

转载于:https://www.cnblogs.com/zhuanzhuruyi/p/5863603.html

HDU 5037 Frog(2014年北京网络赛 F 贪心)相关推荐

  1. 2016 ICPC 北京网络赛 A 恶心模拟 F 循环矩阵,FFT(待补) I 模拟

    2016 ICPC 北京网络赛 A - The Book List 题意:每本书有所属种类,给出原生的存放方式,求按新的方式存放的样子. tags:坑到心态爆炸的题==  直接堆进vector里搞的, ...

  2. HDU/HDOJ 4043 BUPT 235 FXTZ II 2011ACM北京网络赛 D题

    FXTZ II Accept:15     Submit:28 Time Limit:1000MS     Memory Limit:65536KB Description Cirno is play ...

  3. hdu 5037 Frog 贪心 dp

    哎,注意细节啊,,,,,,,思维的严密性..... 11699193 2014-09-22 08:46:42 Accepted 5037 796MS 1864K 2204 B G++ czy Frog ...

  4. HDU 5037 Frog

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5037 题意:一只青蛙从0跳到m,最远能跳l,只能在石头上跳.给出一开始n个石头的位置,我们是上帝,能放 ...

  5. HDU 6889 Graph Theory Class(CCPC网络赛)

    hdu 6889 传说中的人均min25 题意: n个点的完全图,边权为lcm(i+1,j+1),求mst(最小生成树) 题解: 我一开始以为是推公式,毕竟数据范围这么大,但是自己画图来看看mst的情 ...

  6. HDU - 5875 2016 ACM/ICPC 大连网络赛 H题 暴力

    题目链接 题意:给你一个区间l,r一直将val[l]模上val[l+1],val[l+2]...val[r],因为一个模上比前一个数小数是没有意义的,所以需要将每一个点找到右边第一个小于他的点就行. ...

  7. HDU 4001 To Miss Our Children Time(2011年大连网络赛 A 贪心+dp)

    开始还觉得是贪心呢...  给你三类积木叫你叠楼房,给你的每个积木包括四个值:长 宽(可以互换) 高 类型d  d=0:你只能把它放在地上或者放在 长 宽 小于等于 自己的积木上面  d=1:你只能把 ...

  8. hihoCoder1233(2015北京网络赛H题)

    转载自:http://blog.csdn.net/queuelovestack/article/details/48625899 题意: 有n个卡槽,放有体积不同的n个空盒子,每次你可以移动一个空盒子 ...

  9. hihoCoder1228(2015北京网络赛B题)

    题意: 给出一个文本编辑器的容量,给出老板输入的字符串,小写字母代表文本,大写字母代表命令: L:光标左移: R:光标右移: S:在insert模式和另一个输入模式中切换: D:删除光标后面的一个字符 ...

最新文章

  1. 【Groovy】字符串 ( 字符串注入函数 | asBoolean | execute | minus )
  2. wpf template的code写法
  3. MS12_020漏洞
  4. 基于 Blazor 开发五子棋小游戏
  5. JAVA入门级教学之(方法-7)
  6. 统计表达式二叉树操作数个数
  7. 关于运行jar包时的一个错误
  8. 使用Python进行任务调度(进阶篇)
  9. python怎么打包_如何将一整个python工程打包
  10. 小菜面试 String 篇 之 统计一个字符串中数字,字母,的个数
  11. 20191123每日一句
  12. 【网络工程师】 H3C如何配置VLAN-trunk 二层隔离技术
  13. ncm转换mp3文件时遇到问题:未找到文件
  14. Python获取最新省市区列表并绘制中国地图(含港澳台)
  15. JAVA-CPU飙高问题排查
  16. ubuntu 切换中文输入法
  17. hive 建表-复杂数据类型
  18. 解析现代steam教育的黄金法则
  19. 500 Whoops, something went wrong on our end. Try refreshing the page
  20. 软件测试面试真题 | 黑盒测试和白盒测试的基本概念是什么?

热门文章

  1. 前端自动化测试工具:SlimerJS、phantomJS 和 CasperJS
  2. Unity GeometryShader(从一个线框渲染的例子开始)
  3. Mingw下g++编译执行顺序错误
  4. UML的奥妙 - 学习UML笔记(1)
  5. 深度相机 物体三维重建_基于深度相机进行室内完整场景三维重建的方法及系统_2017100513665_说明书_专利查询_专利网_钻瓜专利网...
  6. 机械秒表的使用方法_让console.log()不再是你的唯一选项js日志输出6种方法
  7. 从文件中读出数据显示在表格中_玩转表格:如何在Word表格中进行数据计算?...
  8. php中改变函数路由,php – 如何修改codeigniter中的路由
  9. Mac下的Parallel Windows忘记密码怎么办?
  10. 手机知识:90Hz或120Hz屏幕刷新率有啥区别,看完你就懂了!