C语言:怎样遍历1-N中只含0和1的数字

数字序列应该是;1、10、11、100、101、110……这些看上去就像是二进制表示的1,2,3,4……但是怎样在十进制情形下遍历这些特征数字呢?... 数字序列应该是;1、10、11、100、101、110……这些看上去就像是二进制表示的1,2,3,4……但是怎样在十进制情形下遍历这些特征数字呢? 展开
 我来答
郝在益
推荐于2017-10-04 · TA获得超过2079个赞
知道小有建树答主
回答量:1496
采纳率:54%
帮助的人:639万
展开全部
//第一种:最简单最暴力也最蠢的办法
#include<stdio.h>

int text(int i)
{
int j;
j = i;
while(j>0)
{
if(j%10 > 1)
return 0;
j /= 10;
}
return 1;
}

void main()
{
int n=1;
int i;
printf("输入n:");
scanf("%d",&n);
for(i=1; i<=n; i++)
{
if(text(i) == 1)
printf("%d\n",i);
}
    return;
}

 

//第二种:快速的办法
#include<stdio.h>

void text(int n,int j)
{
if(j*10 > n)
return;
printf("%d\n",j*10);
text(n,j*10);

if(j*10+1 > n)
return;
printf("%d\n",j*10+1);
text(n,j*10+1);
return;
}

void main()
{
int n=1;
int i;
printf("输入n:");
scanf("%d",&n);
printf("1\n");
text(n,1);
    return;
}

百度网友af84c79
2014-06-08 · TA获得超过209个赞
知道小有建树答主
回答量:306
采纳率:0%
帮助的人:201万
展开全部
最大范围65536
for(int i=0;n!=0;i++)
{
n=n/2;
}
一直膜2 和取余
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式