**
(游戏:九个正面和背面)一个 3 x 3 的矩阵中放置了 9 个硬币,这些硬币有些面向上,有些面向下。可以使用 3 x 3 的矩阵中的 0 (正面)或1(反面)表示硬币的状态。下面是一些例子:
0 0 0 1 0 1 1 1 0 1 0 1 1 0 0
0 1 0 0 0 1 1 0 0 1 1 0 1 1 1
0 0 0 1 0 0 0 0 1 1 0 0 1 1 0
每个状态都可以使用一个二进制数表示。例如,前面的矩阵对应到数字 :
000010000 101001100 110100001 101110100 100111110
总共会有 512 种可能性。所以,可以使用十进制数 0, 1,2, 3, 511 来表示这个矩阵的所有状态。编写一个程序,提示用户输入一个在 0 到 511 之间的数字,然后显示用字符 H 和 T表示的对应的矩阵。
下面是一个运行示例:
**
package chapter08;
import org.testng.annotations.IFactoryAnnotation;
import java.util.Scanner;
/**
* @author mazouri
* @create 2020-03-31 14:52
*/
public class Question19 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("Enter a number between 0 and 511: ");
int number = scanner.nextInt();
if (number < 511 && number > 0) {
char[] binaryChars = toBinaryChars(number);
for (int i = 1; i <= binaryChars.length; i++) {
System.out.print(((binaryChars[i - 1] == '0') ? "H" : "T") + " ");
if (i % 3 == 0) {
System.out.println();
}
}
}else {
System.out.print("Please enter Numbers from 0 to 511");
}
}
/**
* @param number 十进制
* @return 二进制数字
*/
public static char[] toBinaryChars(int number) {
char[] result = new char[9];
int i = result.length - 1;
while (number != 0) {
if (number % 2 == 0) {
result[i--] = '0';
} else {
result[i--] = '1';
}
number /= 2;
}
for (int k = i; k >= 0; k--) {
result[k] = '0';
}
return result;
}
}