商城首页欢迎来到中国正版软件门户

您的位置:首页 >C++二进制转十进制方法详解

C++二进制转十进制方法详解

  发布于2026-03-02 阅读(0)

扫一扫,手机访问

C++中二进制转十进制主要有三种方法:1. 手动按权展开,通过循环逐位计算;2. 使用字符串处理,避免溢出并校验输入合法性;3. 利用bitset类进行固定长度转换。

c++怎么将二进制转换为十进制_c++二进制与十进制转换方法

在C++中,将二进制数转换为十进制有多种方法,最常见的是使用数学计算逐位处理,或者借助标准库函数。下面介绍几种实用且清晰的实现方式。

1. 手动计算:按权展开法

二进制转十进制的基本原理是“按权展开”,从右到左每一位的权重是2的幂次(从0开始)。例如,二进制数1101对应的十进制为:

1×2³ + 1×2² + 0×2¹ + 1×2⁰ = 8 + 4 + 0 + 1 = 13

代码实现如下:

#include <iostream>
using namespace std;

int binaryToDecimal(long long n) { int decimal = 0, base = 1; // base 表示当前位的权重(2^i) while (n > 0) { int lastDigit = n % 10; // 取出最后一位 decimal += lastDigit base; // 加上该位对应的十进制值 base = 2; // 权重乘以2(进入下一位) n /= 10; // 去掉最后一位 } return decimal; }

int main() { long long binary; cout << "输入一个二进制数:"; cin >> binary; cout << "对应的十进制是:" << binaryToDecimal(binary) << endl; return 0; }

2. 使用字符串处理更安全的方法

当输入的二进制数较长时,用整数存储可能溢出。改用字符串可以避免这个问题,并且便于验证每一位是否为0或1。

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

int binaryToDecimal(string binaryStr) { int decimal = 0; int power = 1; // 当前位权重,从2^0开始

// 从右往左遍历字符串
for (int i = binaryStr.length() - 1; i >= 0; i--) {
    if (binaryStr[i] == '1') {
        decimal += power;
    } else if (binaryStr[i] != '0') {
        cout &lt;&lt; "错误:包含非二进制字符!" &lt;&lt; endl;
        return -1;
    }
    power *= 2;
}
return decimal;

}

int main() { string binary; cout << "输入一个二进制字符串:"; cin >> binary; int result = binaryToDecimal(binary); if (result != -1) { cout << "对应的十进制是:" << result << endl; } return 0; }

3. 使用bitset进行简单转换(已知长度)

如果你知道二进制位数(比如8位、16位),可以用std::bitset简化转换过程。

#include <iostream>
#include <bitset>
using namespace std;

int main() { string binary = "1101"; bitset<8> bs(binary); // 假设最多8位 cout << "十进制是:" << bs.to_ulong() << endl; return 0; }

注意:to_ulong()会返回无符号长整型,适用于合法二进制字符串。

4. 十进制转二进制(补充)

顺带一提,十进制转二进制常用“除2取余”法:

#include <iostream>
using namespace std;

void decimalToBinary(int n) { if (n == 0) { cout << "0"; return; } while (n > 0) { cout << n % 2; n /= 2; } cout << endl; } // 注意:输出是逆序的,实际应用中可用栈或字符串反转

基本上就这些。手动循环适合学习理解,字符串法最实用,bitset适合固定长度场景。选择合适方法即可。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注