蓝桥杯第五届真题:兰顿蚂蚁

点击查看:蓝桥杯历年真题 题解目录
兰顿蚂蚁

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

思路分析:
1. 虽然写的代码有点多,但是题目真的很简单。
2. 用数组记录格子的状态,   x,y记录蚂蚁的坐标,  s记录蚂蚁的朝向    t记录总步数
3. 我这里的地图使用boolean类型进行记录,这样可以节省内存资源
4. 根据蚂蚁的朝向和当前格子的颜色进行判断,得出新的状态
5. 将新的状态传入f()方法,继续进行判断,每次判断t--,当t==0时,输出蚂蚁位置并返回。
package java_2014_A;
import java.util.*;
/**
 * @author Ren
 */
public class Main008_兰顿蚂蚁 {
    static Scanner in = new Scanner(System.in);
    static int m = in.nextInt();
    static int n = in.nextInt();
    //创建格子地图的大小,m行n列
    static boolean [][] a = new boolean[m][n];
    public static void main(String[] args) {
        // 根据输入的数据,创建地图内容,true代表黑格,false代表白格
        for(int i = 0; i < a.length; i++) {
            for (int j = 0; j < a[1].length; j++) {
                if(in.nextInt()==1) {
                    a[i][j]=true;
                }
            }
        }
        // 记录蚂蚁的当前位置(在数组中的索引,所以要-1)
        int x = in.nextInt();
        int y = in.nextInt();
        // 记录蚂蚁的朝向
        String s = in.next();
        // 记录蚂蚁走的步数
        int t = in.nextInt();
        //调用方法
        f(s,t ,x,y);
    }
    private static void f(String s, int t, int x, int y) {
        if(t==0){
            System.out.println(x+" "+y);
            return;
        }
        if(s.equals("U") || s=="U"){
            if(a[x][y]==true){
                // 蚂蚁头朝上,当前格子为黑格。 需要右转90度 前进一步,当前格子变为白格
                s = "R";           // 改变蚂蚁的方向
                a[x][y] = false;   // 改变格子的颜色
                y++;               // 更新蚂蚁位置所在的坐标
            }else{
                // 蚂蚁头朝上,当前格子为白色。 需要左转90度,前进一步, 当前格子变为黑色
                s = "L";
                a[x][y] = true;
                y--;
            }
            f(s,t-1,x,y);   // 进行下一步的走势判断
        }else if(s.equals("R") || s=="R"){
            if(a[x][y]==true){
                s = "D"; a[x][y]=false; x++;
            }else{
                s = "U"; a[x][y]=true; x--;
            }
            f(s,t-1,x,y);
        }else if(s.equals("D") || s=="D"){
            if(a[x][y]==true){
                s = "L"; a[x][y]=false; y--;
            }else{
                s = "R"; a[x][y]=true; y++;
            }
            f(s,t-1,x,y);
        }else if(s.equals("L") || s=="L"){
            if(a[x][y]==true){
                s = "U"; a[x][y]=false; x--;
            }else{
                s = "D"; a[x][y]=true; x++;
            }
            f(s,t-1,x,y);
        }
    }
}

在这里插入图片描述

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值