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代表不能走的格 子.之 ...
随机推荐
- C#变量类型
在C#语言中,我们把变量分为七种类型,它们分别是:静态变量(static varibles),非静态变量(instance variables),数组元素(array elements),值参数(va ...
- iOS WebView调用JS的一个小坑
假如调用一个函数,传入的参数为String,要以这样的格式传入: let resultStr="1234" self.webView.stringByEvaluatingJavaS ...
- [iOS Keychain本地长期键值存储]
目前本地存储方式大致有:Sqlite,Coredata,NSUserdefaults.但他们都是在删除APP后就会被删除,如果长期使用存储,可以使用Keychain钥匙串来实现. CHKeychain ...
- Newtonsoft.Json动态过滤属性
Newtonsoft.Json动态过滤属性 接口写的多了,会发现很多的问题.同一个dto,不同的action返回的字段个数不一样.往往开发人员因为懒或者各种原因一股脑的全返回,会浪费很多流量且用户体验 ...
- django1.8 提示(1_8.W001) The standalone TEMPLATE_* settings were deprecated in Django 1.8 and the TEMPLATES dictionary takes precedence. You must put the values of the following settings into your defau
原因是升级之后不推荐使用单独的 TEMPLATES_DIR这样的设置了,使用TEMPLATE = []这种就好了 详细见https://openedx.atlassian.net/browse/TNL ...
- Servlet3.0中Servlet的使用
目录 1.注解配置 2.异步调用 3.文件上传 相对于之前的版本,Servlet3.0中的Servlet有以下改进: l 支持注解配置. l 支持异步调用. l 直接有对文件上传的支持. 在这篇 ...
- python列表、元组、字典(四)
列表 如:[11,22,33,44,44].['TangXiaoyue', 'bruce tang'] 每个列表都具备如下功能: class list(object): ""&qu ...
- Nginx个人简单理解
首先我们来补充下一些基本知识: 什么是代理服务器? 先举个简单的例子,现在我们在百度访问谷歌的网站,发现现在进不去,这个时候我们可以FQ(关于FQ,可以借鉴下这个博文:http://zhangge.n ...
- python--文件删除、判断目录存在、字符串替换
昨晚笔试了金山WPS的测试开发卷,做个笔记(但不是答案,只是我的想法),关于文件和字符串的处理正在写入与完善至上一篇的博客中,现在题目如下: 1.使用脚本语言删除E:\abc目录下的所有文件: 利用o ...
- EasyUI-Datagrid 中formatter和group-formatter的使用
1.在表格属性设置函数那块写以下内容: groupFormatter:function(value,rows){ //这里可以看到每一条导入表格中的数据,可以返回group的总结值 }, column ...