文章目录

  • 1、整数部分转二进制字符串的方法
  • 2、小数部分转二进制字符串的方法
  • 3、示例程序
  • 4、获取视频教程
  • 5、版权声明

浮点数据转换为二进制的方法是:

1)把浮点数拆分成两部分,小数点前面的整数和小数点后面的小数。

2)分别把整数和小数部分转换为二进制,保存在字符串中。

3)输出转换后和二进制字符串。

1、整数部分转二进制字符串的方法

1)把十进数除以2,记下余数(余数保存在字符串中),现用商除以2,再记下余数,如此循环,直到商为0。

2)把保存余数的字符串反过来,就是结果。

例如123转化成二进制:

123/2=61余1

61/2=30余1

30/2=15余0

15/2=7余1

7/2=3余1

3/2=1余1

1/1=0余1

结果是1101111,反过来就是1111011。

2、小数部分转二进制字符串的方法

1)把小数乘以2,假设结果是s,如果s大于1,该位二进制值为1,如果小于1,该位二进制值为0;

2)把上一步的结果s去掉整数位,只保留小数位,假设得到结果xs,如果xs等于0,转换结束,如果xs大于0,重复第1)步。

例如0.2转换为二进制:

0.2*2=0.4 0

0.4*2=0.8 0

0.8*2=1.6 1

0.6*2=1.2 1

0.2*2=0.4 0

…… 无限循环

浮点数123.2,转换为二进制的结果是1111011.00110011001100110011(小数点后保留20位)。

3、示例程序

/** 程序名:book.c,此程序用于把浮点数转换为二进制的字符串。* 作者:C语言技术网(www.freecplus.net) 日期:20190525。
*/
#include "stdio.h"
#include <string.h>// 把浮点数的整数部分转换为二进制的字符串。
// dec:待转换的浮点数的整数部分。
// pbin:用于存放转换后的字符串的地址。
void dectobin(const long dec,char *pbin)
{long ys=0;  // 余数。int s=dec;  // 商。int ii=0;   // 位数的计数器。char result[65];  // 转换成二进制后,保存在result中,再反过来存放到pbin中。memset(result,0,sizeof(result));// 把浮点数的整数部分转换为二进制,存放在result中。while (s>0){ys=s%2;s=s/2;result[ii]=ys+'0';ii++;}// 再把result字符串反过来,存放在pbin中。int jj=0;for (;ii>0;ii--){pbin[jj]=result[ii-1];jj++;}pbin[jj]=0; // 出于安全的考虑,加上0表示字符串结束。
}// 把浮点数小数部分转换为二进制的字符串。
// decp:待转换的浮点数的小数部分。
// pbin:用于存放转换后的字符串的地址。
// maxp:指定pbin字符串保留的长度。
void decptobin(const double decp,char *pbin,const int maxp)
{double xs=decp;  // 小数部分。int qz=0;        // 取整的结果。int ii=0;        // 位数的计数器。while (xs>0){qz=(int)(xs*2);      // 小数部分乘2取整。pbin[ii++]=qz+'0';   // 0+'0'='0',1+'0'='1'。xs=xs*2;             // 小数部分乘2。if (xs>=1) xs=xs-1;  // 如果>=1,取整。if (ii==maxp) break;}pbin[ii]=0;  // 出于安全的考虑,加上0表示字符串结束。
}int main()
{double ff=0;printf("请输入一个浮点数:");  scanf("%lf",&ff);char str1[101],str2[101];memset(str1,0,sizeof(str1));dectobin((long)ff,str1);  // 把整数部分转换为二进制,保存在str1中。decptobin(ff-(long)ff,str2,24);  // 把小数部分转换为二进制,保存在str2中。printf("%f的二进制输出是:%s.%s\n",ff,str1,str2);
}

运行效果

4、获取视频教程

百万年薪程序员录制,《C/C++高性能服务开发基础》视频教程已在CSDN学院发布,优惠价12元,地址如下:
https://edu.csdn.net/course/play/29402

5、版权声明

C语言技术网原创文章,转载请说明文章的来源、作者和原文的链接。

来源:C语言技术网(www.freecplus.net)

作者:码农有道

如果这篇文章对您有帮助,请点赞支持,或在您的博客中转发此文,让更多的人可以看到它,谢谢!!!

C语言把浮点数转换为二进制数的方法和示例相关推荐

  1. C语言把字符转换为整数的方法和示例

    文章目录 1.程序要求 2.实现思路 3.获取视频教程 4.版权声明 1.程序要求 把字符'0'转换为数字的0: 把字符'1'转换为数字的1: - 把字符'9'转换为数字的9. 2.实现思路 字符的本 ...

  2. c语言如何浮点数转换为字符串,C语言把浮点数转换为字符串

    1.把float/double格式化输出到字符串 标准的C语言提供了atof函数把字符串转double,但是没有提供把float/double转换为字符串的库函数,而是采用sprintf和snprin ...

  3. C语言极坐标转直角坐标,C语言实现直角坐标转换为极坐标的方法

    本文实例讲述了C语言实现直角坐标转换为极坐标的方法.分享给大家供大家参考,具体如下: #include #include struct complex_s{ double x,y; }; double ...

  4. C语言中将数字转换为字符串的方法

    C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串.以下是用itoa()函数将整数转换为字符串的一个例子: # include <stdio. h> # ...

  5. C语言实现十六进制转换为十进制的方法

    这篇文章主要为大家详细介绍了C语言实现十六进制转换为十进制的方法,文中的示例代码讲解详细,具有一定的借鉴价值,需要的可以参考一下 题目描述 输入一个十六进制数字串,将其转换成为对应的整数并输出转换结果 ...

  6. c语言程序10进制转2进制,C语言十进制数转换为二进制数

    这是一个C语言 do while 循环示例:统计十进制正整数 n 转换为二进制数后,其二进制序列中包含的 1 和 0 的个数. 问题分析 输入:一个正整数. 输出:两个整数:1 的个数和 0 的个数. ...

  7. C语言把浮点数转换为字符串

    文章目录 1.把float/double格式化输出到字符串 2.注意事项 3.获取视频教程 4.版权声明 1.把float/double格式化输出到字符串 标准的C语言提供了atof函数把字符串转do ...

  8. C语言中将数字转换为字符串的方法(转自c语言中文网)

    C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串.以下是用itoa()函数将整数转换为字符串的一个例子: # include <stdio. h> # ...

  9. linux 把数字变字符串,C语言中将数字转换为字符串的方法

    C语言提供了几个标准库函数,可以将字符串转换为任意类型(整型.长整型.浮点型等)的数字.以下是用atoi()函数将字符串转换为整数的一个例子: # include # include void mai ...

最新文章

  1. careercup-C和C++ 13.6
  2. 【机器学习】使用集成学习回归器改善预测模型的得分
  3. powermock模拟对象_使用PowerMock模拟构造函数
  4. ossim系统下nagios监控机器可用性用rrd图形显示
  5. 小汤学编程之JavaEE学习day06——LayUI
  6. python游戏设计教程视频_零基础python教程-用Python设计你的第一个小游戏
  7. c#利用反射+特性实现简单的实体映射数据库操作类(表与类的映射)
  8. mysql_fetch_row()获取显示数据
  9. 如何减小Exe, DLL 的大小
  10. H5分享到微信朋友圈与好友实现思路
  11. java过滤器定义_Java ---Filter过滤器
  12. 摇杆控制方向原理_摇杆电位器原理及结构
  13. android 反编译 jadx,jadx gui下载 jadx(Android反编译gui工具) v0.6.1 官方版 下载-脚本之家...
  14. 每日一题 第二次考试 数据库题目,7.17数据库面试题目补充
  15. 云图-CADViewerX 7.X OCX
  16. 在虚拟机中安装mysql数据库
  17. 论文笔记-Person Re-identification Past, Present and Future
  18. ViewPager+Fragment+ViewPager+Fragment
  19. [C语言] 发牌洗牌
  20. 如何彻底卸载\删除android设备上预装app

热门文章

  1. Python破解ZIP或RAR文件密码
  2. oracle 32 下载,oracle 11g 32位下载
  3. 界面放大_Beachtek推出RED摄影机低噪前置放大器DXA-RED
  4. 5 查询一个小时前_2021国考成绩查询系统登录入口
  5. cmd进入到python安装目录下_在python中安装basemap
  6. vue 上传文件_前后端分离项目,如何优雅实现文件存储!
  7. hive mysql互导_利用Sqoop实现Hive的数据与MySQL数据的互导
  8. python环境变量配置_怎么搭建python环境?很简单,就几步的事
  9. C语言之字符串探究(三):字符串库函数操作——strlen、strcat、strcpy、strcmp
  10. char double java_java从入门到精髓 - Number char double float