nyoj 613 免费馅饼 广搜
免费馅饼
- 描述
- 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼。说来gameboy的人品实在是太好了,这馅饼别处都不 掉,就掉落在他身旁的10米范围内。馅饼如果掉在了地上当然就不能吃了,所以gameboy马上卸下身上的背包去接。但由于小径两侧都不能站人,所以他只 能在小径上接。由于gameboy平时老呆在房间里玩游戏,虽然在游戏中是个身手敏捷的高手,但在现实中运动神经特别迟钝,每秒种只有在移动不超过一米的 范围内接住坠落的馅饼。现在给这条小径如图标上坐标:
为了使问题简化,假设在接下来的一段时间里,馅饼都掉落在0-10这11个位置。开始时gameboy站在5这个位置,因此在第一秒,他只能接到4,5,6这三个位置中其中一个位置上的馅饼。问gameboy最多可能接到多少个馅饼?(假设他的背包可以容纳无穷多个馅饼)
- 输入
- 输入数据有多组。每组数据的第一行为以正整数n(0<n<100000),表示有n个馅饼掉在这条小径上。在结下来的n行中,每行有两个整数x,T(0<T<100000),表示在第T秒有一个馅饼掉在x点上。同一秒钟在同一点上可能掉下多个馅饼。n=0时输入结束。
- 输出
- 每一组输入数据对应一行输出。输出一个整数m,表示gameboy最多可能接到m个馅饼。
提示:本题的输入数据量比较大,建议用scanf读入,用cin可能会超时。 - 样例输入
-
6
5 1
4 1
6 1
7 2
7 2
8 3
0 - 样例输出
-
4
- 来源
- 写错了一个字母,提交了12次才过 千万得注意啊!!!!!
- 分析:
- 数据分析 建表 :
位置 | 第一秒 | 第二秒 | 第三秒 |
4 | 1 | ||
5 | 1 | ||
6 | 1 | ||
7 | 2 | ||
8 | 1 |
- 广搜+递归:
- 2、上右 t2=f[dis-1][time+1]
- 3、下右 t3=f[dis+1][time+1]
#include<stdio.h>
#include<string.h>
int a[][],b[][];
int ans,max;
int maxx(int a,int b)
{
return a>b?a:b;
}
int bfs(int di,int ti)
{
int t1=,t2=,t3=;
if(b[di][ti]>=)
return b[di][ti];
if(ti>max)
return ;
t1=bfs(di,ti+)+a[di][ti+];
if(di>)
t2=bfs(di-,ti+)+a[di-][ti+];
if(di<)
t3=bfs(di+,ti+)+a[di+][ti+];
return b[di][ti]=maxx(t1,maxx(t2,t3));
}
int main()
{
int n,t,d;
while(scanf("%d",&n),n)
{
memset(a,,sizeof(a));
memset(b,-,sizeof(b));
max=-;
while(n--)
{
scanf("%d %d",&d,&t);
if(t>max)
max=t;
++a[d][t];
}
ans=;
printf("%d\n",bfs(,));
}
return ;
}
java:
//package rumen; import java.util.Scanner; public class Main {
/**
* 动态规划
* 类似于数塔问题,
* 但是本题是倒着的数塔,可以有三个方向
*/
public static void main(String[] args) {
Scanner scan=new Scanner(System.in);
while(true){
int N=scan.nextInt();
if(N==0)
break;
int[][] nn=getInput(scan,N);
int T=0;
for(int i=0;i<N;i++){
if(nn[1][i]>T)
T=nn[1][i];
}
int[][] bb=new int[T+1][11];
for(int i=0;i<N;i++){
bb[nn[1][i]][nn[0][i]]++;
}
//寻找最大路径
for(int t=T-1;t>=0;t--){
bb[t][0]+=Math.max(bb[t+1][0],bb[t+1][1]);
bb[t][10]+=Math.max(bb[t+1][10],bb[t+1][9]);
for(int i=1;i<10;i++){
bb[t][i]+=Math.max(bb[t+1][i-1],Math.max(bb[t+1][i],bb[t+1][i+1]));
}
}
//起始位置为5的最大能接到的馅饼数
System.out.println(bb[0][5]);
}
} /**
* 接收输入
*/
public static int[][] getInput(Scanner scan,int N) {
int[][] nn=new int[2][N];
for(int i=0;i<N;i++){
//位置
nn[0][i]=scan.nextInt();
//时间
nn[1][i]=scan.nextInt();
}
return nn;
}
}
nyoj 613 免费馅饼 广搜的更多相关文章
- NYOJ 613 免费馅饼
免费馅饼 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描写叙述 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼.说来gameboy ...
- NYOJ 483 Nightmare 【广搜】+【无标记】
版权声明:长风原创 https://blog.csdn.net/u012846486/article/details/31032479 Nightmare 时间限制:1000 ms | 内存限制: ...
- NYOJ 284 坦克大战 (广搜)
题目链接 描述 Many of us had played the game "Battle city" in our childhood, and some people (li ...
- nyoj 592 spiral grid(广搜)
题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=592 解决以下问题后就方便用广搜解: 1.将数字坐标化,10000坐标为(0,0),这样就 ...
- nyoj 523 双向广搜
题目链接: http://acm.nyist.net/JudgeOnline/problem.php?pid=523 #include<iostream> #include<cstd ...
- nyoj 999——师傅又被妖怪抓走了——————【双广搜】
师傅又被妖怪抓走了 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 话说唐僧复得了孙行者,师徒们一心同体,共诣西方.自宝象国救了公主,承君臣送出城西,沿路饥餐渴饮,悟 ...
- 免费馅饼——G
G. 免费馅饼 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼.说来gameboy的人品实在是太好了,这馅饼别处都不掉,就掉落在他身旁的10米范围内.馅饼如果 ...
- HDU--杭电--1195--Open the Lock--深搜--都用双向广搜,弱爆了,看题了没?语文没过关吧?暴力深搜难道我会害羞?
这个题我看了,都是推荐的神马双向广搜,难道这个深搜你们都木有发现?还是特意留个机会给我装逼? Open the Lock Time Limit: 2000/1000 MS (Java/Others) ...
- HDU 5652(二分+广搜)
题目链接:http://acm.hust.edu.cn/vjudge/contest/128683#problem/E 题目大意:给定一只含有0和1的地图,0代表可以走的格子,1代表不能走的格 子.之 ...
随机推荐
- Google Guava vs Apache Commons for Argument Validation
It is an established good practice to validate method arguments at the beginning of the method body. ...
- Linux/UNIX 定时任务 cron 详解
定时任务( job)被用于安排那些需要被周期性执行的命令.利用它,你可以配置某些命令或者脚本,让它们在某个设定的时间内周期性地运行.cron 是 Linux 或者类 Unix 系统中最为实用的工具之一 ...
- Hook技术
hook钩子: 使用技术手段在运行时动态的将额外代码依附现进程,从而实现替换现有处理逻辑或插入额外功能的目的. 它的技术实现要点有两个: 1)如何注入代码(如何将额外代码依附于现有代码中). 2)如何 ...
- Processing Images
https://developer.apple.com/library/content/documentation/GraphicsImaging/Conceptual/CoreImaging/ci_ ...
- jpa OneToMany
Project, project_id @OneToMany(mappedBy = "project") private Set<Ap> apSet =new Hash ...
- Win10微软官方最终正式版ISO镜像文件
Win10微软官方最终正式版ISO镜像文件 据说Windows 10是微软发布的最后一个Windows版本,下一代Windows将作为Update形式出现.Windows 10将发布7个发行版本,分别 ...
- JavaScript格式化日期
查找格式化日期的方法大都是写日期扩展方法,也许是为了维持jquery easyUI 源码完整性, // 对Date的扩展,将 Date 转化为指定格式的String // 月(M).日(d).小时(h ...
- JAVA 的普通加法运算
利用Scanner类,其中数字输入的函数,利用while循环结构来得到输入的实数,当输入的是字母时,结束循环 源代码: package ccc;import java.util.*;public cl ...
- JSP EL表达式
1 EL表达式简介 EL 全名为Expression Language.EL主要作用: 1.获取数据 EL表达式主要用于替换JSP页面中的脚本表达式,以从各种类型的web域 中检索java对象.获取数 ...
- yum安装指定(特定)版本(旧版本)软件包的方法
在命令行里输入: yum list SDL 注意这里类库的名字是区别大小写的. 参考 http://www.dabu.info/yum-install-specific-version-old-pac ...