C语言十进制转二进制

本文介绍了一个使用C语言实现的十进制数转八位二进制数的程序。该程序利用了itoa函数进行转换,并对输出格式进行了特定处理。当输入96时出现了错误输出,寻求解决办法。
我用C编写了一个十进制转二进制的程序,输出的二进制固定为8位,我用itoa函数来转换进制,但是我输入96后输出的十进制是错误的,求大神解答,代码如下
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int  main()
{
int i,j,x,gs,js; 
char a[100];
while(1)
{

printf("请输入要转换的数字:"); 
scanf("%d",&x);
itoa(x,a,2);
gs=strlen(a);
js=8-gs;
i=0;

for(j=js;j<=7;j++)
{printf("%c",a[i]);
 a[j]=a[i];
 i++;
}
for(i=0;i<js;i++)
{
 a[i]='0';
}
printf("\n");
for(i=0;i<8;i++)
{printf("%c",a[i]);


 } 
return 0;

 } 
C语言实现十进制二进制有多种方法,以下为几种常见方法及代码示例: ### 递归法 递归法的核心思想是不断将十进制数除以2,直到商为0,然后从递归的最深层开始输出余数。 ```c #include <stdio.h> void dec2bin(int dec) { if(dec > 1) dec2bin(dec/2); printf("%d", dec%2); } int main() { int dec; printf("请输入一个十进制数:"); scanf("%d", &dec); printf("对应的二进制数为:"); dec2bin(dec); printf("\n"); return 0; } ``` 这种方法的优点是代码简洁,逻辑清晰,适合理解递归的概念;缺点是递归深度过大会导致栈溢出[^1]。 ### 迭代除2取余法 迭代除2取余法的核心思想是不断将十进制数除以2,记录每次的余数,直到商为0,然后将所有的余数倒序排列,得到该十进制数的二进制表示。 ```c #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> // 函数声明 void decToBinary(int n); int main() { int num; printf("请输入一个十进制数: "); scanf("%d", &num); decToBinary(num); return 0; } // 十进制二进制的函数实现 void decToBinary(int n) { // 假设整数最大不超过32 int binaryNum[32], i = 0; while (n > 0) { // 除以2取余 binaryNum[i] = n % 2; n = n / 2; i++; } // 由于是倒序存储的,因此需要逆序输出 printf("二进制表示为: "); for (int j = i - 1; j >= 0; j--) { printf("%d", binaryNum[j]); } printf("\n"); } ``` 该方法的优点是避免了递归可能带来的栈溢出问题,适用于处理较大的十进制数;缺点是代码相对复杂,需要额外的数组来存储余数[^3]。 ### 数组存储法 数组存储法是将每次除以2的余数存储在数组中,然后逆向输出数组得出转换后的结果。 ```c #include<stdio.h> void change(int num){ int temp; int data[30]; int i=0; for(;num!=0;num=num/2){ temp=num%2; data[i]=temp; i++; } for(int j=i-1;j>=0;j--){ printf("%d",data[j]); } } int main(){ int num; printf("\n输入十进制数\n"); scanf("%d",&num); change(num); } ``` 此方法的优点是直观易懂,便于理解十进制二进制的过程;缺点是数组大小需要预先确定,可能会造成空间浪费[^2]。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值