[题解]USACO 5.2.1 Snail Trails
链接:http://cerberus.delos.com:791/usacoprob2?S=snail&a=uzElkgTaI9d
描述:有障碍的棋盘上的搜索,求从左上角出发最多经过多少个格子。
思路:暴搜
我的实现:
- 1 /*
- 2 ID:zhangyi20
- 3 PROG:snail
- 4 LANG:C++
- 5 */
- 6 #include <iostream>
- 7 #include <cstdio>
- 8 #include <cmath>
- 9 using namespace std;
- 10 #define MaxN 120
- 11 int N,B;
- 12 int mat[MaxN+5][MaxN+5];//0空地 1障碍 2走过
- 13 int Dfs(int i,int j,int Dir)//方向:0向上,1向右,2向下,3向左
- 14 {
- 15 mat[i][j]=2;
- 16 int Ret=0,i_=i,j_=j;
- 17 int tmp1=-1,tmp2=-1;
- 18 if(Dir==0)//向上
- 19 {
- 20 for(i=i-1; ;--i,++Ret)
- 21 {
- 22 if(mat[i][j])
- 23 break;
- 24 mat[i][j]=2;
- 25 }
- 26 if(mat[i][j]==1)//转向
- 27 {
- 28 if(mat[i+1][j-1])
- 29 tmp1=0;
- 30 else
- 31 tmp1=Dfs(i+1,j,3);
- 32 if(mat[i+1][j+1])
- 33 tmp2=0;
- 34 else
- 35 tmp2=Dfs(i+1,j,1);
- 36 Ret+=max(tmp1,tmp2);
- 37 }
- 38 for(i=i+1;i<=i_;++i)
- 39 mat[i][j]=0;
- 40 }
- 41 else if(Dir==1)//向右
- 42 {
- 43 for(j=j+1; ;++j,++Ret)
- 44 {
- 45 if(mat[i][j])
- 46 break;
- 47 mat[i][j]=2;
- 48 }
- 49 if(mat[i][j]==1)//转向
- 50 {
- 51 if(mat[i-1][j-1])
- 52 tmp1=0;
- 53 else
- 54 tmp1=Dfs(i,j-1,0);
- 55 if(mat[i+1][j-1])
- 56 tmp2=0;
- 57 else
- 58 tmp2=Dfs(i,j-1,2);
- 59 Ret+=max(tmp1,tmp2);
- 60 }
- 61 for(j=j-1;j>=j_;--j)
- 62 mat[i][j]=0;
- 63 }
- 64 else if(Dir==2)//向下
- 65 {
- 66 for(i=i+1; ;++i,++Ret)
- 67 {
- 68 if(mat[i][j])
- 69 break;
- 70 mat[i][j]=2;
- 71 }
- 72 if(mat[i][j]==1)//转向
- 73 {
- 74 if(mat[i-1][j-1])
- 75 tmp1=0;
- 76 else
- 77 tmp1=Dfs(i-1,j,3);
- 78 if(mat[i-1][j+1])
- 79 tmp2=0;
- 80 else
- 81 tmp2=Dfs(i-1,j,1);
- 82 Ret+=max(tmp1,tmp2);
- 83 }
- 84 for(i=i-1;i>=i_;--i)
- 85 mat[i][j]=0;
- 86 }
- 87 else//向左
- 88 {
- 89 for(j=j-1; ;--j,++Ret)
- 90 {
- 91 if(mat[i][j])
- 92 break;
- 93 mat[i][j]=2;
- 94 }
- 95 if(mat[i][j]==1)//转向
- 96 {
- 97 if(mat[i-1][j+1])
- 98 tmp1=0;
- 99 else
- 100 tmp1=Dfs(i,j+1,0);
- 101 if(mat[i+1][j+1])
- 102 tmp2=0;
- 103 else
- 104 tmp2=Dfs(i,j+1,2);
- 105 Ret+=max(tmp1,tmp2);
- 106 }
- 107 for(j=j+1;j<=j_;++j)
- 108 mat[i][j]=0;
- 109 }
- 110 return Ret;
- 111 }
- 112 int main()
- 113 {
- 114 freopen("snail.in","r",stdin);
- 115 freopen("snail.out","w",stdout);
- 116 scanf("%d%d",&N,&B);
- 117 int i,j;
- 118 char c;
- 119 for(i=1;i<=B;++i)
- 120 {
- 121 do
- 122 {
- 123 scanf("%c",&c);
- 124 }while(c<'A'||c>'Z');
- 125 scanf("%d",&j);
- 126 mat[j][c-'A'+1]=1;
- 127 }
- 128 for(i=1;i<=N;++i)
- 129 mat[0][i]=mat[N+1][i]=mat[i][0]=mat[i][N+1]=1;//给地图四周打上障碍
- 130 mat[1][1]=2;
- 131 printf("%d\n",max(Dfs(1,1,1),Dfs(1,1,2))+1);
- 132 return 0;
- 133 }
[题解]USACO 5.2.1 Snail Trails的更多相关文章
- USACO 5.2 Snail Trails
Snail TrailsAll Ireland Contest Sally Snail likes to stroll on a N x N square grid (1 <n <= 12 ...
- 洛谷——P1560 [USACO5.2]蜗牛的旅行Snail Trails
P1560 [USACO5.2]蜗牛的旅行Snail Trails 题目描述 萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120). 她总 ...
- 洛谷 P1560 [USACO5.2]蜗牛的旅行Snail Trails(不明原因的scanf错误)
P1560 [USACO5.2]蜗牛的旅行Snail Trails 题目描述 萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120). 她总 ...
- [题解]USACO 1.3 Ski Course Design
Ski Course Design Farmer John has N hills on his farm (1 <= N <= 1,000), each with an integer ...
- [题解]USACO 1.3 Wormholes
Wormholes Farmer John's hobby of conducting high-energy physics experiments on weekends has backfire ...
- 洛谷 P1560 [USACO5.2]蜗牛的旅行Snail Trails
题目链接 题解 一看题没什么思路.写了个暴力居然可过?! Code #include<bits/stdc++.h> #define LL long long #define RG regi ...
- [USACO5.2]蜗牛的旅行Snail Trails(有条件的dfs)
题目描述 萨丽·斯内尔(Sally Snail,蜗牛)喜欢在N x N 的棋盘上闲逛(1 < n <= 120). 她总是从棋盘的左上角出发.棋盘上有空的格子(用“.”来表示)和B 个路障 ...
- 题解 [USACO Mar08] 奶牛跑步
[USACO Mar08] 奶牛跑步 Description Bessie准备用从牛棚跑到池塘的方法来锻炼. 但是因为她懒,她只准备沿着下坡的路跑到池塘,然后走回牛棚. Bessie也不想跑得太远,所 ...
- [USACO5.2]Snail Trails
嘟嘟嘟 一道很水的爆搜题,然后我调了近40分钟…… 错误:输入数据最好用cin,因为数字可能不止一位,所以用scanf后,单纯的c[0]为字母,c[1]数字………………………… #include< ...
随机推荐
- ThinkPad S5立体声混响以及语音识别
smartaudio里面改成语音识别就可以是立体声混响了.但是微软语音识别在国内依然不好用,微软服务在国内太卡了. (联想总是多此一举,各种乱起八糟的软件,给用户造成困难,以前老机子驱动无线网卡锁在L ...
- thrift基础知识
1. 架构图 Thrift 包含一个完整的堆栈结构用于构建客户端和服务器端.下图描绘了 Thrift 的整体架构. 图 1. 架构图 如图所示,图中黄色部分是用户实现的业务逻辑,褐色部分是根据 Thr ...
- gin中使用路由组
package main import ( "github.com/gin-gonic/gin" ) func main() { router := gin.Default() / ...
- ajax返回获取的值在其他地方获取
继续上个问题的后续问题,因为要获取token进行身份验证,但是又不想写死token值,通过以下方式解决: 1.定义一个分离出来的方法. 2.定义一个全局变量.局部变量. 3.把ajax改成同步的.as ...
- 不难懂------react---Immutable的基本使用
一.Immutable简介 Immutable Data 就是一旦创建,就不能再被更改的数据.对 Immutable 对象的任何修改或添加删除操作都会返回一个新的 Immutable 对象.Immut ...
- 一 简单介绍aws。
aws入门 一 什么是aws? /* 概念: AWS就是 Amazon Web Servies, 亚马逊云计算服务平台. 是一款云服务. */ 二 aws可以做什么? // 可以在aws,创建我们需要 ...
- ApacheCN 数据科学译文集 20210313 更新
新增了五个教程: Python 和 Jupyter 机器学习入门 零.前言 一.Jupyter 基础知识 二.数据清理和高级机器学习 三.Web 爬取和交互式可视化 Python 数据科学和机器学习实 ...
- 【第十四期】高德go面经
自我介绍 选一个比较熟悉的项目讲讲 筛选日志的时候,日志格式是不一样的,你们是如何处理的? 处理日志的时候如果日志量比较大会堆积吗?怎么处理的? 日志落盘到机器上,是如何采集的? 采集服务有问题的话可 ...
- Ubuntu下Java JDK安装
1.仓库安装 待更新 2.手动安装 1.下载linux平台sdk. 官网:https://www.oracle.com/technetwork/java/javase/downloads/index. ...
- 自动归档autoArchive By H.l
写点简单的代码,让开发更简单 详情:ios 应用实现快速的临时缓存之模型的自动归档 Demo:https://files.cnblogs.com/files/sixindev/AutoArchiver ...