笨蛋的难题(一)
-
描述
-
笨蛋之所以称为笨蛋,是因为他有点路痴。他一旦不高兴,就必然一个人漫无目的的出去走走。今天下雨了,他又不高兴了,怎么办?那就出去走呗,这不又丢了,这次幸好记下出来时的方向,并且在一张纸上密密麻麻的记下了他拐的弯(他很聪明吧,拐的弯都是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; } }
-
多组测试数据