题意:走迷宫。求走到a[n][n]需要多久。

考场上想的dfs,听老师说最多50分。代码懒得码了,知道是走迷宫就好。

正解:bfs,时间复杂度O(n)。

见代码:

#include<iostream>
using namespace std;
int n,head=,tail=,a[][],h[],l[],t[];
int a1[]={,-,,,},a2[]={,,,-,};
int c1[]={,-,-,,},c2[]={,-,,-,};
int flag[][];
char s;
int main(){
cin>>n;
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
{
cin>>s;
a[i][j]=int(s)-int('A')+;
if(a[i][j]==)
flag[i][j]=0x3f3f3f3f;
}
flag[][]=;
flag[][n]=;
flag[n][]=;
h[]=;
h[]=;
h[]=n;
l[]=;
l[]=n;
l[]=;
while(head!=tail)
{
head++;
int x=h[head],y=l[head];
if(a[x][y]==)
{
for(int i=;i<=;i++)
{
if(x+a1[i]>&&x+a1[i]<=n&&y+a2[i]>&&y+a2[i]<=n)
{
if(flag[x+a1[i]][y+a2[i]]==||flag[x+a1[i]][y+a2[i]]>flag[x][y]+)
tail++;
h[tail]=x+a1[i];
l[tail]=y+a2[i];
flag[x+a1[i]][y+a2[i]]=flag[x][y]+;
}
}
}
if(a[x][y]==)
{
for(int i=;i<=;i++)
{
if(x+a1[i]*>&&x+a1[i]*<=n&&y+a2[i]*>&&y+a2[i]*<=n)
{
if(flag[x+a1[i]*][y+a2[i]*]==||flag[x+a1[i]*][y+a2[i]*]>flag[x][y]+)
tail++;
h[tail]=x+a1[i]*;
l[tail]=y+a2[i]*;
flag[x+a1[i]*][y+a2[i]*]=flag[x][y]+;
}
}
}
if(a[x][y]==)
{
for(int i=;i<=;i++)
{
if(x+c1[i]>&&x+c1[i]<=n&&y+c2[i]>&&y+c2[i]<=n)
{
if(flag[x+c1[i]][y+c2[i]]==||flag[x+c1[i]][y+c2[i]]>flag[x][y]+)
tail++;
h[tail]=x+c1[i];
l[tail]=y+c2[i];
flag[x+c1[i]][y+c2[i]]=flag[x][y]+;
}
}
}
}
if(a[n][n]==)
cout<<"GO to find Marx";
else
cout<<a[n][n];
return ;
}

总而言之,相对简单的普及题。

好题哉!!!

嵊州普及Day1T2的更多相关文章

  1. 嵊州普及Day6T3

    题意:n个点,对于q个询问,有t秒及一个矩形的范围.在此矩形内的数每秒加1,若等于c,则下一秒变为0. 思路:t可能很大,%c+1就可以了.然后一个一个加起来就可以了. 见代码: #include&l ...

  2. 嵊州普及Day6T1

    题意:有一个矩形,由正负整数构成.一个位子的魅力值为相邻的格子,若与邻格同号则减去绝对值,若异号则加上绝对值. 思路:一个格子一个格子计算即可,没什么好说的. 见代码: #include<ios ...

  3. 嵊州普及Day5T4

    题意:两个1,每次可将一个*k,一个*K2,n个问题,问能否达成x,y? 思路:只有将x,y相乘为3次方时,才可能.并且相乘的三次方一定要是x,y的因子. 下面证明:3次方易证,因为对每个k,都会乘三 ...

  4. 嵊州普及Day5T2

    题意:将(w,h)的纸条折成(W,H),最少需几步. 思路:横竖互不干扰,然后最多可折int型一半,拿个函数判断两次比较即可,然后折不了的条件是需要的矩形大于给的矩形. 见代码: #include&l ...

  5. 嵊州普及Day5T1

    题意:有n个商店,自家商店的定价不可高于任何一家商店定价,求自家商店最高定价. 思路:拿个变量打擂台即可,不用解释太多. 见代码: #include<iostream> #include& ...

  6. 嵊州普及Day4T2

    题意:有一个单行走廊,每回合第ai个展柜会冒出来一只鬼,右边尽头有一个人间大炮和向最左传送门(费用均1金币),你需要每回合将所有鬼交换展柜,全部至最右,问若从一到n所有回合结束是需多少金币可射死所有鬼 ...

  7. 嵊州普及Day4T1

    题意:从n个数中选出k个数,使他们任意两数之差都等于m. 思路:任意差值都等于m,不就等价于k个数模m余数相同吗? 然后桶排储蓄一下各数余数即可. 见代码: #include<iostream& ...

  8. 嵊州普及Day4T4

    题意:求最长上升序列长度和方案数. 思路:经典DP,不需什么别的东西,加一个数组储蓄程序数即可,原题300000可能N2会有问题,但问题不大. 见代码: #include<iostream> ...

  9. 嵊州普及Day3T2

    题意:对于n数列的全排列,有多少种可能,是每项前缀和不能整除3.输出可能性%1000000000037. 思路:全部模三,剩余1.2.0,1.2可这样排:1.1.2.1.2.1.2.……2或2.2.1 ...

随机推荐

  1. ubuntu---CUDA 安装注意点总结

    安装CUDA前的基础准备: 1.查看内核.gcc版本并记住. 最好 禁止内核更新,以防止以后工作中意外的系统更新使内核自动更新了,与驱动版本不兼容了.   2.禁用 nouveau驱动.   3.多下 ...

  2. 杭电 2028 ( Lowest Common Multiple Plus )

    链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=2028 题目要求:就是求最大公倍数,我百度了一下,最好实现的算法就是:       公式法 由于 ...

  3. 理解错误的 Arrays.asList()

    简介 Arrays.asList() 作用是将一个数组转换为一个List 集合. String[] myArray = { "Apple", "Banana", ...

  4. 《Java Spring框架》Spring IOC 源码分析

    1.下载源码 源码部署:https://www.cnblogs.com/jssj/p/11631881.html 并不强求,最好是有源码(方便理解和查问题). 2. 创建子项目 Spring项目中创建 ...

  5. HDU 5570:balls 期望。。。。。。。。。。。。。。。

    balls  Accepts: 19  Submissions: 55  Time Limit: 6000/3000 MS (Java/Others)  Memory Limit: 65536/655 ...

  6. 【PAT甲级】1005 Spell It Right (20 分)

    题意: 给出一个非零整数N(<=10^100),计算每位之和并用英文输出. AAAAAccepted code: #include<bits/stdc++.h> using name ...

  7. nodejs中this详解

    最近在用Nodejs进行APP运维服务管理系统开发时发现,nodejs中的this经常会变,查了下资料后发现this在不同的代码位置中代表不同的涵义,在实际运用过程中可以用var self = thi ...

  8. Hot Module Replacement [热模块替换]

    安装了webpack-dev-server后 , 配置 "start": "webpack-dev-server" 然后运行 npm start 会开起一个we ...

  9. 110、Java中String类之字符串文本拆分

    01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...

  10. Java8使用Stream优雅地处理集合

    说明 集合和数组是我们经常会用到的数据结构,在jdk1.8之前,集合和数组的处理并不是很便捷.但是到了JDK1.8之后,使用Stream处理集合会使代码变得更加的简洁明了.作为一名开发者,其实很有必要 ...