笨蛋得难题 (来源:南阳理工大学ACM)java

笨蛋的难题(一)

描述
       笨蛋之所以称为笨蛋,是因为他有点路痴。他一旦不高兴,就必然一个人漫无目的的出去走走。今天下雨了,他又不高兴了,怎么办?那就出去走呗,这不又丢了,这次幸好记下出来时的方向,并且在一张纸上密密麻麻的记下了他拐的弯(他很聪明吧,拐的弯都是90度的弯),0代表左拐,1代表右拐,那么多0、1,他实在看不下去了,正好遇见善良加聪明的你,你能告诉他,他现在面向哪吗?
输入
多组测试数据
第一行
输入:他开始时的面对方向,和他拐弯次数n(0<n<100)。
接着n行数字表示拐的弯。
输出
他现在所面向的方向(West,East,North,South)
样例输入
East  1
0
North   1
1
样例输出
North
East

java解决办法:

说明:输入: 第一行 方向(West,East,North,South)

第二行 转向的次数n

接下来的n行 分别输入每次的方向


import java.util.Scanner;

/**
 * 
 * @author admin 
 * 	描述 
 * 		笨蛋之所以称为笨蛋,是因为他有点路痴。他一旦不高兴,就必然一个人漫无目的的出去走走。
 *      今天下雨了,他又不高兴了,怎么办?那就出去走呗,这不又丢了,这次幸好记下出来时的方向,
 *      并且在一张纸上密密麻麻的记下了他拐的弯(他很聪明吧,拐的弯都是90度的弯),0代表左拐,
 *      1代表右拐,那么多0、1,他实在看不下去了,正好遇见善良加聪明的你,你能告诉他,他现在 面向哪吗? 
 *  输入 	
 *  	 第一行
 *  	输入:他开始时的面对方向,和他拐弯次数n(0<n<100)。 接着n行数字表示拐的弯。 输出
 *     	他现在所面向的方向(West,East,North,South)
 * 
 *         样例输入 East 1 0 North 1 1 样例输出 North East
 * 
 */
// 为了方便,这个部分使用一组测试数据
public class Idiot {

	public static void main(String[] args) {
		Scanner input = new Scanner(System.in);
		String direction = input.nextLine(); // 笨蛋初始面向得方向
		int n = Integer.valueOf(input.nextLine());// 表示笨蛋转弯得次数
		int[] arr = new int[n]; // 存放笨蛋每一次得方向
		for (int i = 0; i < arr.length; i++) {
			arr[i] = Integer.valueOf(input.nextLine());
		}
		input.close();
		for (int i = 0; i < arr.length; i++) {
			direction=computer(direction, arr[i]);
		}
		System.out.println(direction);

	}

	public static String computer(String direction, int t) {
		if ("West".equals(direction)) {
			if (t == 1) {
				direction="North";
			} else {
				direction="South";
			}
		} else if ("East".equals(direction)) {
			if (t == 1) {
				direction="South";
			} else {
				direction="North";
			}
		} else if ("North".equals(direction)) {
			if (t == 1) {
				direction="East";
			} else {
				direction="West";
			}
		} else if ("South".equals(direction)) {
			if (t == 1) {
				direction="West";
			} else {
				direction="East";
			}
		}
		return direction;
	}

}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值