漫游车问题

直接贴代码

public class Interview {

    public static final char FLAG[]={'E', 'S', 'W', 'N'};

    /**
     * 一队机器人漫游车将被美国宇航局降落在火星高原上。漫游车将在这个奇怪的长方形高原上巡游,
     * 以便他们的机载摄像头可以获得周围地形的完整视图,并将其发送回地球。
     * 漫游者的坐标和位置由x和y坐标的组合以及代表四个方向(E, S, W, N)的字母表示。
     * 高原划分为网格以简化导航。比如位置0,0,N,表示漫游车位于左下角并面向北。
     * 为了控制漫游车,美国宇航局发送一串简单的字母。
     * 指令字母是'L','R'和'M'。
     * 'L'和'R'使漫游车分别向左或向右旋转90度,而不会从当前地点移动。
     * 'M'表示前进一个网格点,并保持相同的方向。
     * 假设从(x,y)直接向北移动,就到了(x,y + 1)。
     * INPUT:
     * 第一行输入是平台的右上角坐标,左下角坐标被假定为0,0。
     * 其余的输入是有关已部署的漫游车的信息。每个漫游车都有两行输入。
     * 第一行给出了漫游车的位置,第二行是告诉漫游车如何探索高原的一系列指令。
     * 位置由两个整数和一个由空格分隔的字母组成,对应于x和y坐标以及漫游车当前的方向。
     * 每个漫游车将按顺序完成,这意味着第二个漫游车在第一个漫游车完成移动之前不会开始移动。
     * 输入:
     * 1 2 N
     * LMLMLMLMM
     * 预期产出:
     * 1 3 N
     * 输入:
     * 3 3 E
     * MMRMMRMRRM
     * 预期产出:
     * 5 1 E
     * @param xByInit 车的初始x值
     * @param yByInit 车的初始y值
     * @param flag 车的初始方向
     * @param cmd 车的接下来的指令
     * @return
     */
    public String finish(Integer xByInit,Integer yByInit,Character flag,String cmd){
        if(null==xByInit){
            System.out.println("请输入初始x值");
        }
        if(null==yByInit){
            System.out.println("请输入初始y值");
        }
        if(null==flag){
            System.out.println("请输入初始方向");
        }
        if(null==cmd){
            System.out.println("请输入指令");
        }
        cmd=cmd.toUpperCase();
        int len=FLAG.length;
        // 朝向
        int loc=0;
        for (int i = 0; i < FLAG.length; i++) {
            if(FLAG[i]==flag){
                loc=i;
                break;
            }
        }
        //  'L'和'R'使漫游车分别向左或向右旋转90度,而不会从当前地点移动
        //  'M'表示前进一个网格点,并保持相同的方向
        char[] cmdByChar=cmd.toCharArray();
        for (int i = 0; i <cmdByChar.length; i++) {
            if(cmdByChar[i] == 'L'){
                loc = (loc - 1 + len) % len;
            }else if(cmdByChar[i] == 'R'){
                loc = (loc + 1) % len;
            }else if(cmdByChar[i] == 'M'){
                switch (FLAG[loc]){
                    case 'E':
                        xByInit += 1;
                        break;
                    case 'S':
                        yByInit -= 1;
                        break;
                    case 'W':
                        xByInit -= 1;
                        break;
                    case 'N':
                        yByInit += 1;
                        break;
                }
            }
        }
        StringBuilder stringBuilder=new StringBuilder();
        stringBuilder.append(xByInit);
        stringBuilder.append(" ");
        stringBuilder.append(yByInit);
        stringBuilder.append(" ");
        stringBuilder.append(FLAG[loc]);
        return stringBuilder.toString();
    }

    public static void main(String[] args) {
        int xByInit=1;
        int yByInit=2;
        char flag='N';
        String cmd="LMLMLMLMM";
        System.out.println(new Interview().finish(xByInit,yByInit,flag,cmd));
    }
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值