蓝桥杯 基础练习 01字串(C++)
最近自己在练习,将正确的代码分享同时也是记录便于查看。但有的可能写的太复杂,不一定是最简便的代码。
问题描述
对于长度为5位的一个01串,每一位都可能是0或1,一共有32种可能。它们的前几个是:
00000
00001
00010
00011
00100
请按从小到大的顺序输出这32种01串。
输入格式
本试题没有输入。
输出格式
输出32行,按从小到大的顺序每行一个长度为5的01串。
样例输出
00000
00001
00010
00011
<以下部分省略>
#include <iostream>
using namespace std;
int main()
{
int a[32],b[32][5]={0};
for(int i=0;i<32;i++)
{
a[i]=0+i; //先列出32个十进制数
}
for(int i=0;i<32;i++)
{
for(int j=0;j<5;j++)
{
b[i][4-j]=a[i]%2; //将十进制数化为二进制数,并将01对应二维数组元素
a[i]=a[i]/2;
if(a[i]==0)
break;
}
}
for(int i=0;i<32;i++)
{
for(int j=0;j<5;j++)
{
cout<<b[i][j];
}
cout<<endl;
}
return 0;
}