带小数的十进制转换为二进制
生活随笔
收集整理的這篇文章主要介紹了
带小数的十进制转换为二进制
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
題目描述:
? ? ? ?1.將十進(jìn)制的實(shí)數(shù)轉(zhuǎn)換成二進(jìn)制數(shù)。(Tip:十進(jìn)制小數(shù)轉(zhuǎn)換成二進(jìn)制用乘2取整)
解題思路:分為整數(shù)部分轉(zhuǎn)換和小數(shù)部分轉(zhuǎn)換,兩步操作
整數(shù)部分除2逆向取余
小數(shù)部分乘2正向取整
如:
12.45=1100.0.0111001100
12/2=6..0
6/2=3..0
3/2=1..1
1/2=0..1
結(jié)果為1100
0.45*2=0.9
0.9*2=1.8
0.8*2=1.6
0.6*2=1.2
0.2*2=0.4
0.4*2=0.8
0.8*2=1.6 出現(xiàn)循環(huán)。。。
0.45=0.0111001100
#include<stdio.h> #include<stack> using namespace std; void to2(double n) {stack<char>s;int m=(int)n;double t=n-m; //0.4while(m) // 處理整數(shù) {s.push(m%2);m/=2;}while(!s.empty()){printf("%d",s.top());s.pop();}printf(".");while(t-int(t)!=0) //處理小數(shù)點(diǎn)后的位數(shù),乘2取整法 ,當(dāng)乘2變?yōu)檎麛?shù)后結(jié)束{int temp=int(t*2);printf("%d",temp);t=2*t-int(2*t);}} int main() {double n; scanf("%lf",&n);to2(n);return 0;}
解題思路:分為整數(shù)部分轉(zhuǎn)換和小數(shù)部分轉(zhuǎn)換,兩步操作
整數(shù)部分除2逆向取余
小數(shù)部分乘2正向取整
如:
12.45=1100.0.0111001100
12/2=6..0
6/2=3..0
3/2=1..1
1/2=0..1
結(jié)果為1100
0.45*2=0.9
0.9*2=1.8
0.8*2=1.6
0.6*2=1.2
0.2*2=0.4
0.4*2=0.8
0.8*2=1.6 出現(xiàn)循環(huán)。。。
0.45=0.0111001100
#include<stdio.h> #include<stack> using namespace std; void to2(double n) {stack<char>s;int m=(int)n;double t=n-m; //0.4while(m) // 處理整數(shù) {s.push(m%2);m/=2;}while(!s.empty()){printf("%d",s.top());s.pop();}printf(".");while(t-int(t)!=0) //處理小數(shù)點(diǎn)后的位數(shù),乘2取整法 ,當(dāng)乘2變?yōu)檎麛?shù)后結(jié)束{int temp=int(t*2);printf("%d",temp);t=2*t-int(2*t);}} int main() {double n; scanf("%lf",&n);to2(n);return 0;}
總結(jié)
以上是生活随笔為你收集整理的带小数的十进制转换为二进制的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 十进制负数转二进制
- 下一篇: 互相关函数实现(c语言完整工程,利用cm