如题所述
第1个回答 2011-06-19
#include <stdio.h>
void trans(int x)
{
int a[30];//我算过了,1亿好像才29位的二进制,一般不用算
//这么大的数了吧~~
int i=0,rem;
do{
rem=x%2;x=x/2;
a[i]=rem;
i++;
}while(x!=0);//这个算法看你的代码知道你懂!:)
while(i>0)
printf("%d",a[--i]);
printf("\n");//这就是我的精华了,倒输出正确顺序的数~
}
void main()
{
int d;
printf("请输入一个十进制的正整数:\n");
do scanf("%d",&d);while(d<0);
trans(d);
详见以下参考网站
void trans(int x)
{
int a[30];//我算过了,1亿好像才29位的二进制,一般不用算
//这么大的数了吧~~
int i=0,rem;
do{
rem=x%2;x=x/2;
a[i]=rem;
i++;
}while(x!=0);//这个算法看你的代码知道你懂!:)
while(i>0)
printf("%d",a[--i]);
printf("\n");//这就是我的精华了,倒输出正确顺序的数~
}
void main()
{
int d;
printf("请输入一个十进制的正整数:\n");
do scanf("%d",&d);while(d<0);
trans(d);
详见以下参考网站
参考资料:
第2个回答 推荐于2016-05-30
#include<stdio.h>
void fun(int n)
{
if(n/2) fun(n/2);
printf("%d",n%2);
}
int main()
{
int n;
scanf("%d",&n);
fun(n);
return 0;
}本回答被提问者采纳
void fun(int n)
{
if(n/2) fun(n/2);
printf("%d",n%2);
}
int main()
{
int n;
scanf("%d",&n);
fun(n);
return 0;
}本回答被提问者采纳
第3个回答 2011-06-19
这是个例子,希望有用吧!试下啊
#include<stdio.h>
#include<iostream>
using namespace std;
int main()
{
int a;
scanf("%d",&a);
for(int t=0x8000;t!=0;t=t>>1)
{
if((t&a)!=0) printf("1");
else printf("0");
}
printf("\n");
return 0;
}
#include<stdio.h>
#include<iostream>
using namespace std;
int main()
{
int a;
scanf("%d",&a);
for(int t=0x8000;t!=0;t=t>>1)
{
if((t&a)!=0) printf("1");
else printf("0");
}
printf("\n");
return 0;
}
第4个回答 2011-06-19
1、可以不断与2取模!
2、也可以采用位运算符>>
2、也可以采用位运算符>>