带小数二进制数转换八进制数c语言新代码
时间: 2023-10-17 20:28:13 浏览: 46
以下是将带小数的二进制数转换成八进制数的C语言代码:
```c
#include <stdio.h>
#include <math.h>
int main() {
char binary[20];
int i, integer = 0;
float fraction = 0.0;
printf("请输入一个带小数的二进制数:");
scanf("%s", binary);
// 将二进制数分离整数部分和小数部分
for (i = 0; binary[i] != '.' && binary[i] != '\0'; i++) {
integer = integer * 2 + (binary[i] - '0');
}
if (binary[i] == '.') {
i++;
for (float j = 0.5; binary[i] != '\0'; i++, j /= 2) {
fraction += (binary[i] - '0') * j;
}
}
// 将整数部分转换成八进制数
int octal[20], count = 0;
while (integer != 0) {
octal[count] = integer % 8;
integer /= 8;
count++;
}
// 输出八进制数的整数部分
printf("转换成八进制数为:");
for (i = count - 1; i >= 0; i--) {
printf("%d", octal[i]);
}
// 将小数部分转换成八进制数
if (fraction != 0) {
printf(".");
for (i = 1; i <= 3; i++) {
fraction *= 8;
printf("%d", (int)fraction);
fraction -= (int)fraction;
}
}
printf("\n");
return 0;
}
```
代码解释:
1. 首先,我们定义一个字符数组 `binary`,用于存储输入的二进制数。
2. 然后,我们定义一个整数变量 `integer`,用于存储二进制数的整数部分,以及一个浮点数变量 `fraction`,用于存储二进制数的小数部分。
3. 接下来,我们通过循环遍历字符数组 `binary`,将其分离为整数部分和小数部分,并分别存储到 `integer` 和 `fraction` 变量中。
4. 然后,我们定义一个整型数组 `octal`,用于存储八进制数的整数部分。
5. 我们将 `integer` 转换成八进制数,并存储到 `octal` 数组中。
6. 最后,我们将 `fraction` 转换成八进制数,并输出整个八进制数。
7. 注意:在转换小数部分时,我们只取了小数点后的三位数字,可以根据需要自行修改。
希望能对你有所帮助!