01迷宫---dfs+标记
X星球的一处迷宫游乐场建在某个小山坡上,它是由10x10相互连通的小房间组成的。房间地板上写着一个很大的字母。我们假设玩家是面朝上坡的方向站立,则:L R U D分别表示左右上下;游戏开始,100名玩家被放入一个个小房间,玩家按照地上的字母移动
迷宫地图如下:
UDDLUULRUL
UURLLLRRRU
RRUURLDLRD
RUDDDDUUUU
URUDLLRRUU
DURLRLDLRL
ULLURLLRDU
RDLULLRDDD
UUDDUDUDLL
ULRDLUURRR
请计算:有多少玩家可以走出迷宫,而不是在里面兜圈子?
- 100个玩家对应100个房间,为房间建立一个矩阵存储方向
- 为房间建一个坐标:i,j(i<0||j<0||i>9||j>9)就走出迷宫
- 标记:如果走到曾经走过的房间,则判定为死循环,无法走出房间(因此要对走过的点进行标记)
/*
* 迷宫-暴力dfs+标记*/
public class A1 {
static String[] data=new String[10];//存储每行的房间
static int ans;//结果
static int[][] vis=new int[10][10];//对每个房间的标记
static boolean solve(int i,int j)//solve函数判定玩家是否能走出去;i,j从左上角开始标记
{
if(i<0||i>9||j<0||j>9)
{
return true;
}//走出去
if (vis[i][j]==1)//判断是否已经被做标记
return false;
vis[i][j]=1;//做标记
switch(data[i].charAt(j)){//继续试探下一个
case 'U':
return solve(i-1,j);
case 'D':
return solve(i+1,j);
case 'R':
return solve(i,j+1);
case 'L':
return solve(i,j-1);
default:
return false;
}
}
public static void main(String[] args){
data[0]="UDDLUULRUL";
data[1]="UURLLLRRRU";
data[2]="RRUURLDLRD";
data[3]="RUDDDDUUUU";
data[4]="URUDLLRRUU";
data[5]="DURLRLDLRL";
data[6]="ULLURLLRDU";
data[7]="RDLULLRDDD";
data[8]="UUDDUDUDLL";
data[9]="ULRDLUURRR";
for(int i=0;i<10;++i){
for(int j=0;j<10;++j){
clr(vis);//清空vis,下一个玩家不能使用上一个玩家的vis
boolean res=solve(i,j);
if(res)
ans++;
}
}
System.out.println(ans);
}
private static void clr(int[][] vis)
{
for(int i=0;i<10;i++) {
for (int j = 0; j < 10; j++) {
vis[i][j]=0;//通过遍历,全部清空
}
}
}
}
运行结果:31
思路:
- 对每个玩家进行标记,vis[][]
- 将每个玩家装入data[]
- 用solve函数对玩家进行判断,依次试探,试探后进行标记,下一个玩家记得清空vis
02 9数算式
9213x85674=789314562
左边的乘数与被乘数组合起来刚好为1-9,结果也为1-9,每个一次仅一次
求该类算式一共有多少?
注:乘数与被乘数交换算式为一种
思路:全排列,遍历
1x8 2x7 3x6 5x4
全排列算法 推荐文章