题目:对于长度为4位的一个01串,每一位都可能是0或1,一共有16种可能。它们的前几个是:0000,0001,0010,0011,0100;请按从小到大的顺序输出这16种01串。
我在网上看了几个文章 觉得进制转换的思想做这道题对新人来说更浅显易懂一点
因为刚学到循环的话 其实很多代码新人是看不懂的 所以我这里用新人学到的能理解的方法讲解这道题
这一题第一次看可能会有点迷茫 其实跟进制转换有关联 详情可以去哔哩哔哩看进制转换的相关视频 这里把一个本人觉得讲的不错的转换BV号放在这:BV1Ka4y1W7P1
这题跟十进制转二进制有关联 建议看完上面所发BV号中十转二进制的视频 再来看下面的代码 则会觉得十分简单了
#include<stdio.h>
int main()
{
int i,a,b,c,d;
for (i = 1; i <=16; i++)
{
a = i % 2;
b = i / 2 % 2;
c = i / 2 / 2 % 2;
d = i / 2 / 2 / 2 % 2;
printf("%d%d%d%d\n", d, c, b, a);//printf要放在循环内部
}
return 0;
}