【习题】习题 1 - 用代码将二进制转换为十进制

        欢迎来到博主 Apeiron 的博客,祝您旅程愉快 ! 时止则止,时行则行。动静不失其时,其道光明。


目录

1、缘起

2、算法描述       

3、示例代码

4、相关知识点

5、总结


1、缘起

        我以前在计算二进制转换为十进制的时候,喜欢用笔算,或者电脑在手旁的时候,用电脑自带的程序员计算器进行计算。今天兴起,突然想写一个代码用于计算二进制转换为十进制,不写不知道,一写吓一跳。本来想着这个算法挺简单的,但真正去上手撸代码的时候,却发现事情没有想象的那么简单。

        各位读者,你们先不要看下文,自己先去构思这个算法应该怎么实现,然后再去手撸代码,有困惑的时候再来看看本文,你会发现本文的精妙所在。一定要经过大脑的思考,不然看了也是白搭。


 

2、算法描述       

        程序首先提示用户输入一个二进制数,然后使用 while 循环 将其转换为十进制数。在循环中,程序使用 模运算符(%)除法运算符(/)获得二进制数的每个数字,并使用 pow 函数 计算每个数字所代表的十进制数值。最后,程序将这些值相加,得到二进制数的十进制等价。最后,程序打印出十进制数的值。

注意:在输入二进制数之前,请确保使用的是 long long 类型,以防止二进制数太大而导致溢出。


 

3、示例代码

#include <stdio.h>
#include <math.h>

int main() 
{
    //声明一个二进制数变量,用于存储用户输入的二进制数。
    long long binary_number;

    //定义一个十进制数变量,用于存储转换后的十进制数
    int decimal_number = 0;
       
    //声明一个余数变量,用于存储每次计算二进制数的余数
    int remainder;

    //定义一个自增变量,用于记录当前位数的值
    int i = 0;

    printf("请输入一个二进制数:");
    scanf("%lld", &binary_number);

    while (binary_number != 0)
    {
        //获得二进制的每位数字
        remainder = binary_number % 10;

        binary_number = binary_number / 10;

        //计算每个数字所代表的十进制数值,最后,程序将这些值相加
        decimal_number += remainder * pow(2, i);

        i++;
    }

    printf("转换为十进制数为:%d\n", decimal_number);

    system("pause");
    return 0;
}

关键代码解释: 

        这是一个 while 循环,它会 一位一位地处理二进制数,直到将整个二进制数转换成十进制数。循环中的过程如下:

①  通过 取余运算 获得二进制数的最低位数字,并将其存储到 remainder 变量中。

② 二进制数除以 10,去掉最低位数字。

  通过 remainderi 计算出当前位数所代表的十进制数值,并将其加到 decimal_number 变量中。

④ i 变量加 1,以处理下一位数字。

  循环重复执行以上过程,直到 binary_number 变量的值变成 0。

4、相关知识点

        在 C 语言中,pow() 函数 用于 计算一个数的幂。它接受两个参数,第一个参数是 底数,第二个参数是 指数,返回值是 底数的指数次幂

double pow(double x, double y);

注意:其中,x 是底数,y 是指数,返回值是 xy 次幂

例如,要计算 2 的 3 次幂,可以这样写: 

#include <stdio.h>
#include <math.h>

int main()
{
    double result = pow(2, 3);

    printf("2 raised to the power of 3 is: %f\n", result);

    return 0;
}

        需要注意的是,pow() 函数的返回值类型是 double,如果想要计算整数次幂,可以将指数转换为 double 类型进行计算。此外,在计算浮点数次幂时,可能会出现精度问题,需要注意。 

5、总结

        上述代码用了一个非常巧妙的思想,我直呼大为震惊。计算机把输入的值当做十进制来处理,然后对其 取余取除 操作,取出其中的每一位数值,然后 一位一位地处理 "二进制数"(其实是 0 和 1 这样的十进制数)。将其取出的每一位数值乘以二进制相对应位置的 权重,得到每位二进制所对应的十进制,然后将其每位二进制所对应的十进制进行相加,得到一串二进制数的十进制数。

        本期的分享总结就到这里了,如果有疑问的小伙伴儿,我们在评论区交流嗷~~~,笔者必回,我们下期再见啦 !

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Aperion

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值