十进制小数转二进制

方法:“乘2取整”

对十进制小数乘2得到的整数部分和小数部分,整数部分既是相应的 二进制数码 ,再用2乘小数部分(之前乘后得到新的小数部分),又得到整数和小数部分.
如此不断重复,直到小数部分为0或达到精度要求为止.第一次所得到为最高位,最后一次得到为最低位
如:0.25的二进制
0.25*2=0.5 取整是0
0.5*2=1.0 取整是1
即0.25的二进制为 0.01 ( 第一次所得到为最高位,最后一次得到为最低位)

0.8125的二进制

0.8125*2=1.625 取整是1

0.625*2=1.25 取整是1

0.25*2=0.5 取整是0

0.5*2=1.0 取整是1

即0.8125的二进制是0.1101(第一次所得到为最高位,最后一次得到为最低位)
C语言可以使用栈来实现十进制小数二进制的操作。下面是一个示例代码: ```c #include <stdio.h> #include <stdlib.h> #define MAX_SIZE 100 typedef struct { int top; int data[MAX_SIZE]; } Stack; void initStack(Stack *s) { s->top = -1; } int isEmpty(Stack *s) { return s->top == -1; } int isFull(Stack *s) { return s->top == MAX_SIZE - 1; } void push(Stack *s, int value) { if (isFull(s)) { printf("Stack is full.\n"); exit(1); } s->data[++s->top] = value; } int pop(Stack *s) { if (isEmpty(s)) { printf("Stack is empty.\n"); exit(1); } return s->data[s->top--]; } void decimalToBinary(double decimal) { Stack s; initStack(&s); int integerPart = (int)decimal; double fractionalPart = decimal - integerPart; // 换整数部分 while (integerPart > 0) { push(&s, integerPart % 2); integerPart /= 2; } // 输出整数部分的二进制表示 printf("整数部分的二进制表示为: "); while (!isEmpty(&s)) { printf("%d", pop(&s)); } // 小数部分 if (fractionalPart > 0) { printf("."); int precision = 10; // 设置小数部分的精度 while (fractionalPart > 0 && precision > 0) { fractionalPart *= 2; int bit = (int)fractionalPart; printf("%d", bit); fractionalPart -= bit; precision--; } } printf("\n"); } int main() { double decimal; printf("请输入一个十进制小数: "); scanf("%lf", &decimal); decimalToBinary(decimal); return 0; } ``` 这段代码使用了一个栈来存储二进制数的每一位,首先将十进制小数的整数部分换为二进制,然后将小数部分换为二进制并输出。你可以根据需要修改精度。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值