C语言算法之将十进制数转换成二进制数

导语:在C语言中没有将其他进制的数直接输出为二进制数的工具或方法,输出为八进制数可以用%o,输出为十六进制可以用%x,输出为二进制就要我们自行解决了。下面给大家讲述一下如何编程实现将十进制数转换成二进制数。

 

先将源代码展示给大家:

#include <stdio.h>
void main()
{
    //进制转换函数的声明
    int transfer(int x);
    int x;
    printf("请输入一个十进制数:");
    scanf("%d",&x);
    printf("转换成二进制数是:%d\n",transfer(x));
}
int transfer(int x)
{
    int p=1,y=0,yushu;
    while(1)
    {
        yushu=x%2;
        x/=2;
        y+=yushu*p;
        p*=10;
        if(x<2)
        {
            y+=x*p;
            break;
        }
    }
    return y;
}
具体算法体现在函数体内,使用了一个while(1)的死循环,当结果产生后跳出循环。变量yushu是每一次循环内产生的余数,变量x每次循环都会被赋予新的值,这个新的值就是每一次循环内产生的商。当产生的商小于2时即产生了最后的结果(二进制数),然后跳出循环。

例如:函数自变量若为7,用自变量7除以2,得到第一次循环产生的余数为1,第一次循环产生的商为3;用第一次循环产生的商3除以2,得到第二次循环产生的余数为1,第二次循环产生的商为1。

变量y的存放也是有一定技巧的,由于每次产生的余数都小于2并且都是最后二进制数中需要按位展现出来的,因此每一次循环产生的余数都要合理地进行存放。第一次产生的余数放在个位,第二次产生的余数放在十位,第三次产生的余数放在百位......依次类推,直至某一次循环产生的商小于2,最后再把小于2的那个商放在最高位。变量p的作用就是控制位数,变量y的初始值定为0,变量p的初始值定为1,每次循环内变量p都自乘10,每次循环内都让变量y加上yushu*p,这样就实现了余数的按位存放。最后将小于2的那个商乘以p加到变量y中,得到最后的二进制数。

例如:还是以自变量7为例,第一次循环后y的值为1,第二次循环内if语句之前y的值为11,if语句内y的值变为111,111即为7的二进制数。

 

注意:变量p的自乘要放在变量y加上yushu*p之后!顺序不能颠倒!
--------------------- 
作者:De掉所有bug 
来源:CSDN 
原文:https://blog.csdn.net/weixin_41676881/article/details/80745177 
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用C语言中的标准函`strtol()`将二进制字转换为十进制,然后再使用标准函`sprintf()`将十进制字转换为字符串并存储在一个`char`类型的变量中。 下面是一个简单的示例代码: ```c #include <stdio.h> #include <stdlib.h> int main() { char binary_num[] = "101011"; // 二进制字字符串 char decimal_str[20]; // 存储十进制的字符串变量 long decimal_num = strtol(binary_num, NULL, 2); // 将二进制字转换为十进制 sprintf(decimal_str, "%ld", decimal_num); // 将十进制转换为字符串 printf("Binary number: %s\n", binary_num); printf("Decimal number: %ld\n", decimal_num); printf("Decimal number as string: %s\n", decimal_str); return 0; } ``` 输出结果为: ``` Binary number: 101011 Decimal number: 43 Decimal number as string: 43 ``` 上述代码中,`strtol()`函的第一个参是要转换的字符串,第二个参是一个指向`char`类型指针的指针,用于返回未转换部分的指针(在这里我们不需要,所以设置为`NULL`),第三个参是基,这里设置为2表示将字符串解析为二进制字。 `sprintf()`函的第一个参是要存储结果的字符组,第二个参是格式化字符串,用于指定输出的格式,这里我们使用`%ld`表示输出长整型字。第三个参是要转换的字。 注意,上述代码只能处理较小的二进制字,因为`strtol()`函和`sprintf()`函都有范围限制。如果要处理更大的字,可以考虑使用其他方法,比如自己实现二进制十进制算法

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值