蓝桥杯练习------01字串

这篇博客探讨了两种方法来生成所有可能的五位01串。方法一是使用嵌套循环的暴力求解,而方法二是通过将十进制数转换为二进制。博客强调了在进行二进制转换时的注意事项,并展示了如何避免常见错误。代码示例详细解释了转换过程,对于理解二进制和十进制之间的转换具有指导意义。
摘要由CSDN通过智能技术生成

问题描述
对于长度为5位的一个01串,每一位都可能是0或1,一共有32种可能。它们的前几个是:

00000
00001
00010
00011
00100

请按从小到大的顺序输出这32种01串。

输入格式
本试题没有输入。

输出格式
输出32行,按从小到大的顺序每行一个长度为5的01串。

样例输出
00000
00001
00010
00011
<以下部分省略>
 

方法一:暴力

#include<bits/stdc++.h>
using namespace std;
int main()
{
	int i,j,k,l,m;
	for(i=0;i<=1;i++)
	{
		for(j=0;j<=1;j++)
		{
			for(k=0;k<=1;k++)
		    {
		    	for(l=0;l<=1;l++)
		    	{
		    		for(m=0;m<=1;m++)
		    		{
		    			printf("%d%d%d%d%d\n",i,j,k,l,m);
					}
				}
			}	
		}
	}
	return 0;
}

方法二:十进制转二进制

注意注意!t=n,只能在该位置,不能放在循环里面,呜呜,说多了都是泪

#include<bits/stdc++.h>
using namespace std;
int main()
{
	int a[5];
	int n=0,t;
	int i,j;
	for(n=0;n<=31;n++)
	{
		for(i=4,t=n;i>=0;i--) 
	    {
		    //t=n,一定不能放在这个循环里面!!! 
			a[i]=t%2;
			t/=2;	
	    }
	    for(j=0;j<=4;j++)
	     printf("%d",a[j]);
	    printf("\n");
	}	
	return 0;
}

然后,感觉这一段代码可能是十进制转二进制常规套路?

for(i=4,t=n;i>=0;i--) 
	    {
		    //t=n,一定不能放在这个循环里面!!! 
			a[i]=t%2;
			t/=2;	
	    }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值