问题描述
对于长度为5位的一个01串,每一位都可能是0或1,一共有32种可能。它们的前几个是:
00000
00001
00010
00011
00100
请按从小到大的顺序输出这32种01串。【蓝桥杯基础练习】
输出格式
输出32行,按从小到大的顺序每行一个长度为5的01串。
样例输出
00000
00001
00010
00011.....
解法一:
将数字1-32循环遍历转换为2进制数,使用格式化字符串输出按格式输出
代码如下:
public class Main12 {
public static void main(String[] args) {
for(int i=0;i<32;i++) {
String ret=Integer.toBinaryString(i);//转换为二进制字符串
int n=Integer.parseInt(ret);//转换为数字
System.out.printf("%05d\n",n);//格式化输出
}
}
}
解法二:
将数字1-32循环遍历计算计算每一位的二进制并按顺序输出
代码如下:
public class Main12 {
public static void main(String[] args) {
for(int i=0;i<32;i++) {
System.out.print(i%32/16);
System.out.print(i%16/8);
System.out.print(i%8/4);
System.out.print(i%4/2);
System.out.println(i%2);
}
}
}