蓝桥杯练习系统-01字串(一次循环简单解法)
开局一句话:
这个题实在是简单题,本来是不写这篇博客的,网上一看全是用五个循环来做的,我觉得我的方法比较简单吧,但是可能需要了解的东西要多一点,一看到这道题的时候,我就直接想到了直接用二进制数来做,可能由于之前刚好做了进制转换的题,然后简单的写了一个版本,发现随着数在减小,位数也在变化,我又想到了DecimalFormat类,也是之前练过,能够控制格式输出,最后10行代码,100分通过.
问题描述
对于长度为5位的一个01串,每一位都可能是0或1,一共有32种可能。它们的前几个是:
00000
00001
00010
00011
00100
请按从小到大的顺序输出这32种01串。
输入格式
本试题没有输入。
输出格式
输出32行,按从小到大的顺序每行一个长度为5的01串。
样例输出
00000
00001
00010
00011
<以下部分省略>
代码
import java.text.DecimalFormat;
public class Main {
public static void main(String[] args){
for(int i=0;i<=31;i++) {
System.out.print(new DecimalFormat("00000").format((Integer.parseInt(Integer.toBinaryString(i)))));
System.out.println();
}
}
}
总结
简单的说一下我的代码
“00000” 是我要输出的五位数格式
Integer.toBinaryString(i) 是把i转换为一个二进制字符串
Integer.parseInt(str) 是把字符串str中的字符型数字转换为int型数字的,有不能转换的会发生错误,当然这道题里全是能转换的.