免费馅饼

时间限制: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. 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. ...

  2. Linux/UNIX 定时任务 cron 详解

    定时任务( job)被用于安排那些需要被周期性执行的命令.利用它,你可以配置某些命令或者脚本,让它们在某个设定的时间内周期性地运行.cron 是 Linux 或者类 Unix 系统中最为实用的工具之一 ...

  3. Hook技术

    hook钩子: 使用技术手段在运行时动态的将额外代码依附现进程,从而实现替换现有处理逻辑或插入额外功能的目的. 它的技术实现要点有两个: 1)如何注入代码(如何将额外代码依附于现有代码中). 2)如何 ...

  4. Processing Images

    https://developer.apple.com/library/content/documentation/GraphicsImaging/Conceptual/CoreImaging/ci_ ...

  5. jpa OneToMany

    Project, project_id @OneToMany(mappedBy = "project") private Set<Ap> apSet =new Hash ...

  6. Win10微软官方最终正式版ISO镜像文件

    Win10微软官方最终正式版ISO镜像文件 据说Windows 10是微软发布的最后一个Windows版本,下一代Windows将作为Update形式出现.Windows 10将发布7个发行版本,分别 ...

  7. JavaScript格式化日期

    查找格式化日期的方法大都是写日期扩展方法,也许是为了维持jquery easyUI 源码完整性, // 对Date的扩展,将 Date 转化为指定格式的String // 月(M).日(d).小时(h ...

  8. JAVA 的普通加法运算

    利用Scanner类,其中数字输入的函数,利用while循环结构来得到输入的实数,当输入的是字母时,结束循环 源代码: package ccc;import java.util.*;public cl ...

  9. JSP EL表达式

    1 EL表达式简介 EL 全名为Expression Language.EL主要作用: 1.获取数据 EL表达式主要用于替换JSP页面中的脚本表达式,以从各种类型的web域 中检索java对象.获取数 ...

  10. yum安装指定(特定)版本(旧版本)软件包的方法

    在命令行里输入: yum list SDL 注意这里类库的名字是区别大小写的. 参考 http://www.dabu.info/yum-install-specific-version-old-pac ...