描述
小Hi在水平桌面上放置了一个立方体。初始时,上下左右前后6个面的编号依次是1、6、4、3、2、5。
现在立方体经过若干次翻滚,每次翻滚是向前翻滚90度(F)、向后翻滚90度(B)、向左翻滚90度(L)、向右翻滚90度(R)之一。
请你计算翻滚后上下左右前后6个面的编号依次是多少?
输入
一个由FBLR组成的序列。
长度不超过100。
输出
输出6行,每行一个整数。依次是上下左右前后6个面的编号。
样例输入
LB
样例输出
2
5
1
6
4
3
package com.xiaonei;
import java.util.Scanner;
public class test4 {
private static int[] a = {1, 6, 4, 3, 2, 5};
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
char arr[] = new char[str.length()];
for (int i = 0; i < arr.length; i++) {
arr[i] = str.charAt(i);
}
for (int j = 0; j < arr.length; j++) {
if (arr[j] == 'F') {
F();
}
if (arr[j] == 'B') {
F();
F();
F();
}
if (arr[j] == 'L') {
L();
}
if (arr[j] == 'R') {
L();
L();
L();
}
}
for(int i = 0; i < a.length; i++) {
System.out.println(a[i]);
}
}
public static void F() {
swap(a,0,5);
swap(a,5,4);
swap(a,5,1);
}
public static void L() {
swap(a,1,3);
swap(a,0,1);
swap(a,1,2);
}
public static void swap (int[] arr,int a,int b) {
int temp = arr[a];
arr[a] = arr[b];
arr[b] = temp;
}
}