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代表不能走的格 子.之 ...
随机推荐
- Akka: actor应用的一些小结
1.消息: 1) case class是scala中一个不可变对象(当然你可以让他成为可变的),通过不可变对象来进行消息传递可以更加明确内容,也能保证线程安全 2) 在Java中如果你将class对象 ...
- Spring MVC过滤器-委派过滤器代理(DelegatingFilterProxy)
org.springframework.web.filter中有一个特殊的类——DelegatingFilterProxy,该类其实并不能说是一个过滤器,它的原型是FilterToBeanProxy, ...
- xml小记1
xml小记1 关于边框的实现 这是一个比较简单的东西,但是今天莫名的低效率,在这上面花了比较多的时间.之前有咨询过同学如何实现单向的边框,他们采用的方法是调用别人的接口. 我采用的方法如下: < ...
- RNN 入门教程 Part 3 – 介绍 BPTT 算法和梯度消失问题
转载 - Recurrent Neural Networks Tutorial, Part 3 – Backpropagation Through Time and Vanishing Gradien ...
- IOS OC 计算器算法(不考虑优先级)
个人见解:为还在计算器算法方面迷惑的同学一个数据处理解决方案:定义一个可变数组array,一个可变字符串str,使字符通过[array addObject:str];方法添加到可变数组,每当触发运算符 ...
- C#中值类型和引用类型图解
举几个值类型和引用类型的内存配置: 值类型存储在栈中,引用类型堆里: 1,数组 数组是引用类型,但是数组的元素可以是值类型或引用类型 2. 结构 结构是值类型,简略的看个例子 struct sampl ...
- 获取字符串中每个字符出现的次数(利用TreeMap)
案例:"aababcabcdabcde",获取字符串中每一个字母出现的次数要求结果:a(5)b(4)c(3)d(2)e(1)分析1:定义一个字符串(可以改进为键盘录入)2:定义一个 ...
- WinForm------BarManager中各种属性设置
1.offset:红色Tool距离左边Tool的偏移量
- JQuery------prevAll(),nextAll(),attr()方法的使用
$(this).nextAll(".Rec").find("input").attr("checked", false); $(this). ...
- spring-boot-note
1 java配置和注解配置相结合,不需要任何的xml配置即可 2 spring tool suite 3 src/main/resources/banner.txt http://patorjk.co ...