C++用指针输入字符串的方式输入二进制数,转换为无符号整型的十进制数
时间: 2024-02-12 15:07:22 浏览: 52
可以通过以下代码实现:
```c++
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char* binary = new char[32]; // 二进制字符串最大长度为32位
cin >> binary; // 输入二进制字符串
int len = strlen(binary);
unsigned int decimal = 0;
for(int i = 0; i < len; i++) {
decimal = decimal * 2 + binary[i] - '0'; // 将每一位二进制数转换为十进制数
}
cout << decimal << endl; // 输出转换后的十进制数
delete[] binary; // 释放内存
return 0;
}
```
首先创建一个长度为32的字符数组来存储输入的二进制字符串,然后使用`cin`输入该字符串。接着,通过`strlen`函数获取二进制字符串的长度,并使用一个循环将每一位二进制数转换为十进制数,最后输出转换后的十进制数。需要注意的是,这里使用无符号整型来存储转换后的十进制数,因为二进制数不包含符号位。最后,别忘了释放内存。
相关问题
c++二进制字符串转换无符号整型
将一个二进制字符串转换为无符号整型,首先需要明确二进制字符串的表示方式。二进制是一种由0和1组成的数字系统,每一位表示一个2的幂次。例如,二进制数1010表示10,其中第一位表示2^3,第二位表示2^2,第三位表示2^1,第四位表示2^0。因此,可以通过对每位进行计算,并将结果相加得到最终的无符号整型值。
要将二进制字符串转换为无符号整型,可以使用以下步骤:
1. 首先,获取二进制字符串的长度。
2. 创建一个变量,用于存储最终的无符号整型值,初始值设为0。
3. 从左到右遍历二进制字符串,从最高位开始。
4. 对于每一位,将其与相应的权值相乘。
5. 将乘积与无符号整型值累加,得到新的无符号整型值。
6. 继续遍历下一位。
7. 重复步骤4至6,直到遍历完所有位。
8. 返回最终的无符号整型值。
举例来说,假设有一个二进制字符串"1010",按照上述步骤进行转换:
1. 字符串长度为4。
2. 创建变量unsigned_value,并将其设为0。
3. 遍历字符串,由左至右。
4. 第一位是1,与2^3相乘得到8。
5. 将乘积8与unsigned_value累加,得到新的unsigned_value为8。
6. 继续遍历下一位。
7. 第二位是0,与2^2相乘得到0。
8. 将乘积0与unsigned_value累加,unsigned_value保持不变。
9. 继续遍历下一位。
10. 第三位是1,与2^1相乘得到2。
11. 将乘积2与unsigned_value累加,得到新的unsigned_value为10。
12. 继续遍历下一位。
13. 第四位是0,与2^0相乘得到0。
14. 将乘积0与unsigned_value累加,unsigned_value保持不变。
15. 遍历完所有位,返回最终的unsigned_value为10。
通过按照上述步骤进行计算,即可将二进制字符串转换为无符号整型。
C++用指针处理字符串实现二进制转十进制
可以用以下代码实现:
```c++
#include <iostream>
#include <cstring>
#include <cmath>
using namespace std;
int binaryToDecimal(char *binary) {
int len = strlen(binary);
int decimal = 0;
for (int i = 0; i < len; i++) {
decimal += (binary[i] - '0') * pow(2, len - i - 1);
}
return decimal;
}
int main() {
char binary[100];
cout << "请输入一个二进制数:";
cin >> binary;
int decimal = binaryToDecimal(binary);
cout << "转换后的十进制数为:" << decimal << endl;
return 0;
}
```
在这个程序中,我们首先使用 `strlen` 函数获取二进制数的长度,并定义一个变量 `decimal` 来存储转换后的十进制数。
然后使用循环遍历二进制数的每一位,将其转换为对应的十进制数,并加入到 `decimal` 变量中。
最后输出转换后的十进制数即可。
相关推荐
![cpp](https://img-home.csdnimg.cn/images/20210720083646.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)