【算法】进制转换

目录

1. 二进制数、八进制数、十六进制数转换为十进制数

2. 十进制数转换为二进制数、八进制数、十六进制数

3. 二进制数和十六进制数的相互转换

4. 使用电脑计算器进行进制转换


1. 二进制数、八进制数、十六进制数转换为十进制数

十进制数的每一位都是10的指数幂。如,

1998 = 1\times 10^{3}+9\times 10^{2}+9\times 10^{1}+8\times 10^{0}

将这个思路应用于二进制数、八进制数、十六进制数,就能将这些数转换为十进制数。

二进制数101转换为十进制数:

101=1\times 2^{2}+0\times 2^{1}+1\times 2^{0}=5

八进制数123转换为十进制数:

123=1\times 8^{2}+2\times 8^{1}+3\times 8^{0}=83

十六进制数1FD转换为十进制数:

1FD=1\times 16^{2}+15\times 16^{1}+13\times 16^{0}=509

2. 十进制数转换为二进制数、八进制数、十六进制数

将这个思路应用于二进制数、八进制数、十六进制数,就能将十进制数转换为二进制数、八进制数、十六进制数。

十进制数57转换为二进制数:

111001

十进制数57转换为八进制数:

71

十进制数57转换为十六进制数:

39

给定一个十进制数M(32位整数),以及需要转换的进制数N(2 ≤ N ≤ 16)。将十进制数M转化为N进制数:

#include <iostream>
#include <string>
#include <algorithm>
using namespace std;

int main()
{
    int m, n;
    cin >> m >> n;
    if (m == 0)
    {
        cout << 0 << endl;
    }

    string ans;
    string hash = "0123456789ABCDEF"; // 表示映射关系
    
    bool positive = true;
    if (m < 0)
    {
        m = -m; // 如果m是负数,取相反数,变成正数
        positive = false;
    }

    while (m != 0)
    {
        ans += hash[m % n]; // 将余数拼接到字符串
        m /= n;
    }

    if (positive = false)
    {
        ans += "-"; // 如果m本来是负数,加上负号
    }

    reverse(ans.begin(), ans.end()); // 倒置字符串
    cout << ans << endl;
    return 0;
}

3. 二进制数和十六进制数的相互转换

4位二进制数和1位十六进制数是相互对应的(即4位的二进制数0000 ~ 1111,就是1位的十六进制数0 ~ F)。

二进制数和十六进制数的对应关系
二进制数十六进制数
00000
00011
00102
00113
01004
01015
01106
01117
10008
10019
1010A
1011B
1100C
1101D
1110E
1111F

二进制数0111101010011100转换为十六进制数:

0111 1010 1001 1100

   7       A      9       C

十六进制数8AF7转换为二进制数:

   8       A       F      7

1000 1010 1111 0111

4. 使用电脑计算器进行进制转换

将计算器切换为程序员选项:

将十进制数16转换为二进制数、八进制数、十六进制数:

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值