问题描述
对于长度为5位的一个01串,每一位都可能是0或1,一共有32种可能。它们的前几个是:
00000
00001
00010
00011
00100
请按从小到大的顺序输出这32种01串。
输入格式
本试题没有输入。
输出格式
输出32行,按从小到大的顺序每行一个长度为5的01串。
样例输出
00000
00001
00010
00011
<以下部分省略>
public class _01字串 {
public static void main(String[] args) {
int x = 0, n = 32;
for (int i = 0; i < 32; i++) {
int tmp = x;
tmp = tenTotwo(tmp);
// 1为 int 类型、0代表前面要补位的字符、2代表字符串的长度、d表示参数为整数类型
String s = String.format("%05d", tmp);
System.out.println(s);
x++;
}
}
public static int tenTotwo(int num) {
String a = "";// 用字符串拼接
while (num != 0) {// 利用十进制转二进制除2法
a = num % 2 + a;
num = num / 2;
}
if (a != "") {
num = Integer.parseInt(a);
}
return num;
}
}
方法有点繁琐但是满分,懒得简化了