C语言中怎样调用函数将十进制转换成二进制?

如上

1、打开visualC++6.0-文件-新建-文件-C++SourceFile。

2、输入预处理命令和主函数:

#include<stdio.h>           /*输入输出头文件*/

voidmain()/*空类型:主函数*/

3、定义变量和数组的数据类型并输入一个十进制:

intb[16],x,k,r,i;/*定义变量和数组的数据类型为整型*/

printf("输入一个十进制:");/*输出文字提示*/

    scanf("%d",&x);         /*输入一个十进制数字*/

k=-1;/*将-1赋给k*/

4、用除R取余倒计法将十进制的数转化成二进制的数:

do/*用循环将十进制的数转化成二进制的数*/

{

r=x%2;/*用除R取余倒计法计算二进制*/

b[++k]=r;/*将值赋给数组*/

x/=2;/*将原数除2*/

    }while(x>=1);

5、输出结果:

    for(i=k;i>=0;i--)        /*将上面倒计的数正回来*/

printf("%d",b[i]);/*输出结果*/

printf("\n");

6、完整的源代码:

#include<stdio.h>           /*输入输出头文件*/

voidmain()/*空类型:主函数*/

{

intb[16],x,k,r,i;/*定义变量和数组的数据类型为整型*/

printf("输入一个十进制:");/*输出文字提示*/

    scanf("%d",&x);         /*输入一个十进制数字*/

k=-1;/*将-1赋给k*/

do/*用循环将十进制的数转化成二进制的数*/

{

r=x%2;/*用除R取余倒计法计算二进制*/

b[++k]=r;/*将值赋给数组*/

x/=2;/*将原数除2*/

    }while(x>=1);

    for(i=k;i>=0;i--)        /*将上面倒计的数正回来*/

printf("%d",b[i]);/*输出结果*/

printf("\n");

}

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-09-20

如果是在windows下,可以使用itoa()函数来进行转换,如:

#include <stdio.h>
#include <stdlib.h>
void main()
{
char str[100];
int n=100;
itoa( n, str, 2 );
printf("%s\n", str );
}

itoa是广泛应用的非标准C语言扩展函数。由于它不是标准C语言函数,所以不能在所有的编译器中使用。

头文件:#include <stdlib.h>

函数原型:char*itoa(int value,char*string,int radix);

函数说明:int value 被转换的整数,char *string 转换后储存的字符数组,int radix 转换进制数,如2,8,10,16 进制等,将数字按要求转换为对应进制的字符串

因为itoa并不是一个标准的C函数,它是Windows特有的,所以若在linux下进行二进制转换,就要自己动手自定义函数来实现了。

通用版本参考代码:

第2个回答  推荐于2017-09-30
void printBinary(int n)
{
if(n>1)printBinary(n/2);
printf("%d",n%2);
}

这样就可以把十进制的n变成二进制数出本回答被提问者采纳
第3个回答  2008-04-23
void printfBinary(unsigned int n)
{
if (n != 0)
{
printfBinary(n >> 1);
printf("%d", (n & 1));
}
}
这样就可以把十进制的n变成二进制输出
第4个回答  2008-05-05
#include "stdio.h"
#include "stdlib.h"

#define MAX 50
#define OK 1
#define ERROR 0
#define YES 1
#define NO 0

typedef int ElemType;
typedef int Status;
typedef struct tagStack{
ElemType data[MAX];
int top;
}Stack;

void InitStack(Stack *s){
s->top=-1;
}

Status isEmpty(Stack *s){
if(s->top==-1) return YES;
return NO;
}

Status Push(Stack *s,ElemType elme){
if(s->top>MAX)return ERROR;
s->top++;
s->data[s->top]=elme;
return OK;
}

ElemType Pop(Stack *s){
if(s->top==-1) return -1;
return s->data[s->top--];
}
void zhuanhuan(int flag,int n)
{
int b;
ElemType elemy;
Stack mystack;
InitStack(&mystack);
while(flag!=0){
b=flag%2;
if(Push(& mystack,b)==ERROR){
printf("ERROR\n");
break;
}
flag=flag/n;

}
printf("\n");
while(isEmpty(& mystack)!=YES){
elemy=Pop(& mystack);
printf("%d ",elemy);
}
printf("\n");

}

void run()
{
int num,choice,n;
printf("\n\t*Please input a number you want exchange:");
scanf("%d",&num);
if(num<0)
{printf("You must input a number(>0)\n");
scanf("%d",&num); }
printf("input you want zhuanhuan de jinzhi :") ;
scanf("%d",&n);
zhuanhuan(num,n);
}
void main()
{
run();
}
相似回答