codevs1105 过河
1105 过河
2005年NOIP全国联赛提高组
时间限制: 1 s
空间限制: 128000 KB
题目等级 : 钻石 Diamond
题目描述 Description
在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧。在桥上有一些石子,青蛙很讨厌踩在这些石子上。由于桥的长度和青蛙一次跳过的距离都是正整数,我们可以把独木桥上青蛙可能到达的点看成数轴上的一串整点:0,1,……,L(其中L是桥的长度)。坐标为0的点表示桥的起点,坐标为L的点表示桥的终点。青蛙从桥的起点开始,不停的向终点方向跳跃。一次跳跃的距离是S到T之间的任意正整数(包括S,T)。当青蛙跳到或跳过坐标为L的点时,就算青蛙已经跳出了独木桥。
题目给出独木桥的长度L,青蛙跳跃的距离范围S,T,桥上石子的位置。你的任务是确定青蛙要想过河,最少需要踩到的石子数。
输入描述 Input Description
输入第一行有一个正整数L(1<=L<=109),表示独木桥的长度。第二行有三个正整数S,T,M,分别表示青蛙一次跳跃的最小距离,最大距离,及桥上石子的个数,其中1<=S<=T<=10,1<=M<=100。第三行有M个不同的正整数分别表示这M个石子在数轴上的位置(数据保证桥的起点和终点处没有石子)。所有相邻的整数之间用一个空格隔开。
输出描述 Output Description
输出只包括一个整数,表示青蛙过河最少需要踩到的石子数。
样例输入 Sample Input
10
2 3 5
2 3 5 6 7
样例输出 Sample Output
2
数据范围及提示 Data Size & Hint
数据规模
对于30%的数据,L<=10000;
对于全部的数据,L<=109。
对于30%的数据,L<=10000;
对于全部的数据,L<=109。
这道题去年暑假考过,今天刚弄明白。
不难看出,10^9不是随便开个数组就能解决的,但石子个数最多只有100个,这就为离散化提供了条件。
桥很长,石子很少,所以可能某两个石子之间距离特别大,如果这个距离大过了所有可能走的步数的最小公倍数,那么就可以直接截掉这一块(无论怎么走结果都相同),于是问题得到解决。
由于s和t都是1~10的数,所以索性把1~10的数的乘积2520作为模,来截独木桥
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int dp[],a[],s,t,m,l,stone[],d[];
int main(){
memset(dp,/,sizeof(dp));
scanf("%d%d%d%d",&l,&s,&t,&m);
for(int i=;i<=m;i++)scanf("%d",&a[i]);
sort(a+,a+m+);
for(int i=;i<=m;i++)d[i]=(a[i]-a[i-])%;
for(int i=;i<=m;i++)a[i]=a[i-]+d[i],stone[a[i]]=;
dp[]=;l=a[m]+t;
for(int i=;i<=l;i++){
for(int j=s;j<=t;j++){
if(i-j>=){
dp[i]=min(dp[i-j],dp[i]);
}
dp[i]+=stone[i];
}
}
int ans=0x7fffffff;
for(int i=l-t;i<=l;i++){
ans=min(ans,dp[i]);
}cout<<ans;
}
codevs1105 过河的更多相关文章
- [codevs1105][COJ0183][NOIP2005]过河
		[codevs1105][COJ0183][NOIP2005]过河 试题描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青 ... 
- [LeetCode] Frog Jump 青蛙过河
		A frog is crossing a river. The river is divided into x units and at each unit there may or may not ... 
- A*算法 -- 八数码问题和传教士过河问题的代码实现
		前段时间人工智能的课介绍到A*算法,于是便去了解了一下,然后试着用这个算法去解决经典的八数码问题,一开始写用了挺久时间的,后来试着把算法的框架抽离出来,编写成一个通用的算法模板,这样子如果以后需要用到 ... 
- 袋鼠过河---DP
		题目:一只袋鼠要从河这边跳到河对岸,河很宽,但是河中间打了很多桩子,每隔一米就有一个,每个桩子上都有一个弹簧,袋鼠跳到弹簧上就可以跳的更远,每个弹簧力量不同,用一个数字代表它的力量,如果弹簧力量为5, ... 
- NOIP2005过河[DP 状态压缩]
		题目描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一次跳过的距离都是正整数,我们可以把独木桥上青蛙可能到达的点看成数 ... 
- ACM 过河问题
		过河问题 时间限制:1000 ms | 内存限制:65535 KB 难度:5 描述 在漆黑的夜里,N位旅行者来到了一座狭窄而且没有护栏的桥边.如果不借助手电筒的话,大家是无论如何也不敢过桥去的 ... 
- NOIP 2005 青蛙过河
		做题记录:2016-08-10 21:58:09 题目描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一次跳过的距离都 ... 
- 过河问题nyoj47
		时间限制:1000 ms | 内存限制:65535 KB 难度:5 描述 在漆黑的夜里,N位旅行者来到了一座狭窄而且没有护栏的桥边.如果不借助手电筒的话,大家是无论如何也不敢过桥去的.不幸的是 ... 
- 商人过河问题(DFS)
		问题描述:3个商人带着3个仆人过河,过河的工具只有一艘小船,只能同时载两个人过河,包括划船的人.在河的任何一边,只要仆人的数量超过商人的数量,仆人就会联合起来将商人杀死并抢夺其财物,问商人应如何设计过 ... 
随机推荐
- 在pycharm中执行脚本没有报错但输出显示Redirection is not supported.
			没有新式语法错误,但是输出显示Redirection is not supported.(不支持重定向) 在stockflow中找到是因为从IDE中运行脚本的原因,比如pycharm,所有IDE都提供 ... 
- ruby 正则表达式
			Ruby学习笔记-正则表达式 Posted on 2011-11-29 17:55 Glen He 阅读(4998) 评论(0) 编辑 收藏 1.创建正则表达式 a) reg1 = /^[a-z]*$ ... 
- Machine Learning No.10: Anomaly detection
			1. Algorithm 2. evaluating an anomaly detection system 3. anomaly detection vs supervised learning 4 ... 
- 版本名称SNAPSHOT、alpha、beta、release、GA含义
			Alpha:是内部测试版,一般不向外部发布,会有很多Bug.一般只有测试人员使用.Beta:也是测试版,这个阶段的版本会一直加入新的功能.在Alpha版之后推出.RC:(Release Candida ... 
- SpringBoot2.0之整合ActiveMQ(发布订阅模式)
			发布订阅模式与前面的点对点模式很类似,简直一毛一样 注意:发布订阅模式 先启动消费者 公用pom: <project xmlns="http://maven.apache.org/PO ... 
- Contiki 2.7 Makefile 文件(六)
			5.第五部分 ifndef CONTIKI $(error CONTIKI not defined! You must specify where CONTIKI resides!) endif if ... 
- PYTHON 爬虫笔记十一:Scrapy框架的基本使用
			Scrapy框架详解及其基本使用 scrapy框架原理 Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 其可以应用在数据挖掘,信息处理或存储历史数据等一系列的程序中.其最初是为了 ... 
- Apache CGI 配置
			在/etc/apache2/apache2.conf末尾添加 ServerName lacalhost:80 然后启动CGI模块: sudo a2enmod cgi 3.重启Apache: syste ... 
- matlab打开文件对话框
			[filename, pathname, filterindex] = uigetfile({'*.xyz', '点云文件 (*.xyz)';'*.*', 'All Files (*.*)'},'请选 ... 
- Html+CSS3技术实现动画、天气图标动态效果 效果很酷
			1. [代码][CSS]代码 <svg version="1.1" id="sun" class="climacon c ... 
