免费馅饼

时间限制:1000 ms  |  内存限制:65535 KB
难度:3
 
描述
都说天上不会掉馅饼,但有一天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 免费馅饼 广搜的更多相关文章

  1. NYOJ 613 免费馅饼

    免费馅饼 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描写叙述 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼.说来gameboy ...

  2. NYOJ 483 Nightmare 【广搜】+【无标记】

    版权声明:长风原创 https://blog.csdn.net/u012846486/article/details/31032479 Nightmare 时间限制:1000 ms  |  内存限制: ...

  3. NYOJ 284 坦克大战 (广搜)

    题目链接 描述 Many of us had played the game "Battle city" in our childhood, and some people (li ...

  4. nyoj 592 spiral grid(广搜)

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=592 解决以下问题后就方便用广搜解: 1.将数字坐标化,10000坐标为(0,0),这样就 ...

  5. nyoj 523 双向广搜

    题目链接: http://acm.nyist.net/JudgeOnline/problem.php?pid=523 #include<iostream> #include<cstd ...

  6. nyoj 999——师傅又被妖怪抓走了——————【双广搜】

    师傅又被妖怪抓走了 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 话说唐僧复得了孙行者,师徒们一心同体,共诣西方.自宝象国救了公主,承君臣送出城西,沿路饥餐渴饮,悟 ...

  7. 免费馅饼——G

    G. 免费馅饼 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼.说来gameboy的人品实在是太好了,这馅饼别处都不掉,就掉落在他身旁的10米范围内.馅饼如果 ...

  8. HDU--杭电--1195--Open the Lock--深搜--都用双向广搜,弱爆了,看题了没?语文没过关吧?暴力深搜难道我会害羞?

    这个题我看了,都是推荐的神马双向广搜,难道这个深搜你们都木有发现?还是特意留个机会给我装逼? Open the Lock Time Limit: 2000/1000 MS (Java/Others)  ...

  9. HDU 5652(二分+广搜)

    题目链接:http://acm.hust.edu.cn/vjudge/contest/128683#problem/E 题目大意:给定一只含有0和1的地图,0代表可以走的格子,1代表不能走的格 子.之 ...

随机推荐

  1. PTA 链表删除结点的题目测试

    链表删除结点 题目描述 输入一个正整数repeat(0 < repeat < 10),做repeat次下列运算: 输入一个正整数n(0 < n < 10)和一组( n 个 )整 ...

  2. Python编码格式的指定方式

    参考自: http://python.jobbole.com/85852/, 原文探究的更深,有兴趣的可以去看看. 简介来讲就是使用一种特殊的注释来声明编码格式,如何判断这种格式也用了很简单粗暴有效的 ...

  3. K米评测

    调研,评测 1)评测 体验: 流畅度不足. 遥控按钮太过偏右,对大屏手机用户不够友好. ui风格不统一,矩形,圆角矩形,圆形混用,圆角矩形的圆角半径也不相同. 状态栏不是沉浸式的,观感较差,特别是白色 ...

  4. mybatis报错Mapped Statements collection does not contain value for com.inter.IOper

    首页 > 精品文库 > mybatis报错Mapped Statements collection does not contain value for com.inter.IOper m ...

  5. Bitmap四种属性

    http://blog.csdn.net/rabbit_in_android/article/details/49967461 Bitmap: (1)     public Bitmap (int w ...

  6. 磁盘里的B,MB,GB,TB储存单位是怎么换算大小的?

    磁盘里的B,MB,GB,TB是怎么换算大小的? 1TB=1024GB1GB=1024MB1MB=1024KB1KB=1024Byte 注:Byte就是B也就是字节KB是千字节MB是兆GB是吉字节 即千 ...

  7. spring-boot-cli

  8. 初识Hadoop一,配置及启动服务

    一.Hadoop简介: Hadoop是由Apache基金会所开发的分布式系统基础架构,实现了一个分布式文件系统(Hadoop Distributed File System),简称HDFS:Hadoo ...

  9. 枚举类型Enum

    包java.dataStructure中,文件名Enum_demo.java 在JDK5中引入了一个新的关键字——enum,可以直接定义枚举类型 在申明枚举类的时候,也可以申明属性.方法和构造函数,但 ...

  10. thinkphp连接数据库

    版本:3.1.1 连接数据库的具体位置 thinkphp/Config/convention.php,默认修改数据库在这里就可以了 但是为了方便,把数据库配置写到Index/Conf/config.p ...