过河 2005年NOIP全国联赛提高组(离散化+dp)
1105 过河
2005年NOIP全国联赛提高组
在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧。在桥上有一些石子,青蛙很讨厌踩在这些石子上。由于桥的长度和青蛙一次跳过的距离都是正整数,我们可以把独木桥上青蛙可能到达的点看成数轴上的一串整点:0,1,……,L(其中L是桥的长度)。坐标为0的点表示桥的起点,坐标为L的点表示桥的终点。青蛙从桥的起点开始,不停的向终点方向跳跃。一次跳跃的距离是S到T之间的任意正整数(包括S,T)。当青蛙跳到或跳过坐标为L的点时,就算青蛙已经跳出了独木桥。
题目给出独木桥的长度L,青蛙跳跃的距离范围S,T,桥上石子的位置。你的任务是确定青蛙要想过河,最少需要踩到的石子数。
输入第一行有一个正整数L(1<=L<=109),表示独木桥的长度。第二行有三个正整数S,T,M,分别表示青蛙一次跳跃的最小距离,最大距离,及桥上石子的个数,其中1<=S<=T<=10,1<=M<=100。第三行有M个不同的正整数分别表示这M个石子在数轴上的位置(数据保证桥的起点和终点处没有石子)。所有相邻的整数之间用一个空格隔开。
输出只包括一个整数,表示青蛙过河最少需要踩到的石子数。
10
2 3 5
2 3 5 6 7
2
数据规模
对于30%的数据,L<=10000;
对于全部的数据,L<=109。
#include<iostream>
#include<cstdio>
#include<cstring> #define N 1000007
#define inf 0x3f3f3f3f using namespace std;
int f[N],a[N],flag[N];
int s,t,n,m,ans,cnt; int main()
{
scanf("%d%d%d%d",&n,&s,&t,&m);
for(int i=;i<=m;i++) scanf("%d",&a[i]),flag[a[i]]=;
memset(f,/,sizeof f);f[]=flag[];
for(int i=;i<=n;i++)
for(int j=s;j<=t;j++)
if(flag[i]) f[i]=min(f[i],f[max(i-j,)]+);
else f[i]=min(f[i],f[max(i-j,)]);
ans=inf;
for(int i=n-t;i<=n;i++) ans=min(ans,f[i]);
printf("%d\n",ans);
return ;
}
坏掉,30暴力
/*
桥距离很长,但石子很少
考虑在不影响答案的情况下缩减石头间的距离
就是不改变相对位置
可以对(1~10)的最小公倍数取模,因为青蛙跳的长度在1~10间。
试了几次下界就出来了,跑得飞快。
*/
#include<cstdio>
#include<algorithm>
#include<cstring> #define N 110 using namespace std;
int L,S,T,M;
int a[N],b[N*N*],f[N*N*]; int main()
{
scanf("%d%d%d%d",&L,&S,&T,&M);
for (int i=; i<=M; i++) scanf("%d",&a[i]);
sort(a+,a+M+);
if (S==T)
{
int ans=;
for (int i=; i<=M; i++)
if (a[i]%S==)ans++;
printf("%d",ans);
return ;
}
int last=;
for (int i=; i<=M; i++)
{
int tmp=a[i];
if (a[i]-last>=)a[i]=a[i-]+;
else a[i]=a[i-]+a[i]-last;
last=tmp;
b[a[i]]=;
}
memset(f,0x3f,sizeof(f));
f[]=;
for (int i=S;i<=a[M]+T;i++)
for (int j=i-T;j<=i-S;j++)
if (j>=)f[i]=min(f[i],f[j]+b[i]);
int ans=0x3f3f3f3f;
for (int i=a[M];i<=a[M]+T; i++)
ans=min(ans,f[i]);
printf("%d",ans);
return ;
}
过河 2005年NOIP全国联赛提高组(离散化+dp)的更多相关文章
- Codevs 1105 过河 2005年NOIP全国联赛提高组
1105 过河 2005年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 在河上有一座独木桥,一只青蛙 ...
- 等价表达式 2005年NOIP全国联赛提高组(栈模拟)
P1054 等价表达式 题目描述 明明进了中学之后,学到了代数表达式.有一天,他碰到一个很麻烦的选择题.这个题目的题干中首先给出了一个代数表达式,然后列出了若干选项,每个选项也是一个代数表达式,题目的 ...
- Codevs 1069 关押罪犯 2010年NOIP全国联赛提高组
1069 关押罪犯 2010年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description S 城现有两座监狱,一共 ...
- Codevs 1218 疫情控制 2012年NOIP全国联赛提高组
1218 疫情控制 2012年NOIP全国联赛提高组 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description H 国有 n 个城市,这 ...
- Codevs 3289 花匠 2013年NOIP全国联赛提高组
3289 花匠 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 花匠栋栋种了一排花,每株花都 ...
- Codevs 1173 最优贸易 2009年NOIP全国联赛提高组
1173 最优贸易 2009年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description [问题描述] C 国有n ...
- Codevs 3731 寻找道路 2014年 NOIP全国联赛提高组
3731 寻找道路 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找 ...
- Codevs 1138 聪明的质监员 2011年NOIP全国联赛提高组
1138 聪明的质监员 2011年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 小 T 是一名质量监督员, ...
- Codevs 1217 借教室 2012年NOIP全国联赛提高组
1217 借教室 2012年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 在大学期间,经常需要租借教 ...
随机推荐
- FTP配置
常用的匿名FTP配置项 anonymous_enable=YES 是否允许匿名用户访问 anon_umask=022 匿名用户所上传文件的权限 ...
- LINUX-JPS工具
JPS工具 jps(Java Virtual Machine Process Status Tool)是JDK 1.5提供的一个显示当前所有java进程pid的命令,简单实用,非常适合在linux/u ...
- F - Shooter
UVA___10535 The shooter is in a great problem. He is trapped in a “2D” maze with a laser gun and can ...
- dstat系统分析工具的使用
1.安装 方法一:yum #yum install -y dstat 方法二:rpm 官网下载地址: http://dag.wieers.com/rpm/packages/dstat #wget ht ...
- 完美解决在Servlet中出现一个输出中文乱码的问题
@Override public void doPost(HttpServletRequest reqeust, HttpServletResponse response) throws Servle ...
- Java Web学习总结(29)——Java Web中的Filter和Interceptor比较
1. 背景 在设计web应用的时候,用户登录/注册是必不可少的功能,对用户登录信息进行验证的方法也是多种多样,大致可以认为如下模式:前端验证+后台验证.根据笔者的经验,一般会在前端进行一些例如是否输入 ...
- ansible roles例子
#理解 changed_when failed_when become become_user ansible_become ansible_become_user static #检查group_v ...
- java 日历计算农历和节假日的工具类
背景 业务需求需要后端提供这样的接口,网上找了很多java代码例子,虽然功能实现了 但是不完善,特别是节日那一块儿.然后百度发现有这样的插件,但是信息也是java后端提供的非js 然后在开源js插件找 ...
- 【驱动开发】file_operations ---linux 2.6.30
路径: linux-2.6.30/include/linux/fs.h struct file_operations { struct module *owner; loff_t ...
- VNC Viewer 设置屏幕分辨率-解决屏幕分辨率问题
https://blog.csdn.net/runningtortoises/article/details/51425332