蓝桥杯2017javaA组真题详解

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

思路: 

  1. 对每个玩家进行标记,vis[][]
  2. 将每个玩家装入data[]
  3. 用solve函数对玩家进行判断,依次试探,试探后进行标记,下一个玩家记得清空vis

02 9数算式

9213x85674=789314562

左边的乘数与被乘数组合起来刚好为1-9,结果也为1-9,每个一次仅一次

求该类算式一共有多少?

注:乘数与被乘数交换算式为一种

 思路:全排列,遍历

1x8 2x7 3x6 5x4 

 全排列算法 推荐文章

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值