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

如上... 如上 展开
 我来答
肥仙女a
高粉答主

2020-05-04 · 我是游戏小达人,专注于分享游戏资讯。
肥仙女a
采纳数:477 获赞数:115599

向TA提问 私信TA
展开全部

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");

}

kaixingui2012
推荐于2017-09-20 · TA获得超过4.2万个赞
知道大有可为答主
回答量:1.4万
采纳率:81%
帮助的人:6411万
展开全部

如果是在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下进行二进制转换,就要自己动手自定义函数来实现了。

通用版本参考代码:

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友d127579
推荐于2017-09-30 · TA获得超过1663个赞
知道小有建树答主
回答量:634
采纳率:0%
帮助的人:0
展开全部
void printBinary(int n)
{
if(n>1)printBinary(n/2);
printf("%d",n%2);
}

这样就可以把十进制的n变成二进制数出
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xniren
2008-04-23 · TA获得超过1154个赞
知道小有建树答主
回答量:554
采纳率:100%
帮助的人:518万
展开全部
void printfBinary(unsigned int n)
{
if (n != 0)
{
printfBinary(n >> 1);
printf("%d", (n & 1));
}
}
这样就可以把十进制的n变成二进制输出
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友9e20e08d0
2008-05-05 · 超过14用户采纳过TA的回答
知道答主
回答量:39
采纳率:0%
帮助的人:0
展开全部
#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();
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式