用c语言实现二进制转十进制
时间: 2024-10-07 11:03:51 浏览: 139
在 C 语言中,将二进制数转换成十进制可以采用循环和位操作的方式。以下是一个简单的函数示例:
```c
#include <stdio.h>
int binaryToDecimal(long long num) {
int decimal = 0;
int base = 1;
while (num > 0) {
int remainder = num % 10; // 取余得到当前二进制位
decimal += remainder * base; // 加上当前位对应的十进制值
num /= 10; // 向左移一位去掉最低有效位
base *= 2; // 下一位的基数翻倍
}
return decimal;
}
int main() {
long long binaryNum;
printf("请输入一个二进制数字(例如:1010): ");
scanf("%lld", &binaryNum);
int decimalValue = binaryToDecimal(binaryNum);
printf("该二进制数 (%lld) 转换成十进制是 %d.\n", binaryNum, decimalValue);
return 0;
}
```
在这个程序中,`binaryToDecimal` 函数接收一个二进制数作为输入,通过不断取余并累加到 `decimal` 中,实现了从二进制到十进制的转换。
相关问题
c语言实现二进制转十进制
二进制转十进制的实现方法如下:
```c
#include <stdio.h>
int main() {
int binary, decimal = 0, base = 1;
printf("请输入一个二进制数:");
scanf("%d", &binary);
while (binary > 0) {
int digit = binary % 10;
decimal += digit * base;
binary /= 10;
base *= 2;
}
printf("转换后的十进制数为:%d\n", decimal);
return 0;
}
```
这段代码可以将输入的二进制数转换为十进制数并输出。
用C语言实现二进制进制转换为十进制
在C语言中,可以使用位操作符和循环结构来将二进制数转换成十进制。这里是一个简单的函数示例,它接受一个字符串形式的二进制数,并返回相应的十进制值:
```c
#include <stdio.h>
#include <string.h>
int binaryToDecimal(char* binary) {
int decimal = 0;
int base = 1; // 从右往左,每一位对应的权值递增
int len = strlen(binary); // 获取二进制字符串长度
for (int i = len - 1; i >= 0; i--) {
if (binary[i] == '1') { // 如果当前位是1
decimal += base; // 将权值加到总和上
}
base *= 2; // 下一位的权值是上一位的两倍
}
return decimal;
}
int main() {
char binaryNum[] = "1010"; // 示例二进制数
int decimalNum = binaryToDecimal(binaryNum);
printf("二进制 %s 转换为十进制是 %d\n", binaryNum, decimalNum);
return 0;
}
```
这个程序首先初始化一个变量`decimal`作为结果,然后从二进制字符串的右端开始遍历,每次遇到'1'就加上相应的权重`base`。`base`随着遍历位置向左移动而翻倍。最后返回得到的`decimal`值。
阅读全文