博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用循环分别实现将10进值整数和小数变成二进制数(Java)
阅读量:2165 次
发布时间:2019-05-01

本文共 816 字,大约阅读时间需要 2 分钟。

public void test6(){

/*使用循环分别实现将10进值整数和小数变成二进制数*/
/*转整数部分为二进制
 * 十进制整数转换为二进制整数采用"除2取余,逆序排列"法。
 * 具体做法是:用2去除十进制整数,可以得到一个商和余数
 * ;再用2去除商,又会得到一个商和余数,如此进行,直到商为零时为止,
 * 然后把先得到的余数作为二进制数的低位有效位,
 * 后得到的余数作为二进制数的高位有效位,依次排列起来。 
 * 
 * 10/2 =5   余数0 
 * 5/2=2   余数 1
 * 2/2=1    0
 * 1/2=0    1   
* */
     int num =5;
    String str="";
    while(num/2!=0){
    int yushu = num%2;
            str =yushu+str;   //"0" +"1"
    num = num/2;
    }
    str = num+str;
    System.out.println(str);
        }

@Test
public void test7(){
/*转小数部分为2进制
 * 十进制小数转换成二进制小数采用"乘2取整,顺序排列"法。具体做法是:
 * 用2乘十进制小数,可以得到积,将积的整数部分取出,再用2乘余下的小数部分,
 * 又得到一个积,再将积的整数部分取出,如此进行,直到积中的小数部分为零,
 * 或者达到所要求的精度为止。 然后把取出的整数部分按顺序排列起来,
* 先取的整数作为二进制小数的高位有效位,后取的整数作为低位有效位
 * */

double d = 0.8125;      //  1.625    1      double ji = d*2;

String str="0.";
while((ji-(int)ji)!=0){
                
    str = str+(int)ji;
    ji = (ji-(int)ji)*2;
    }
    str = str+(int)ji;
    System.out.println(str);
        }
 

转载地址:http://jmjzb.baihongyu.com/

你可能感兴趣的文章
Leetcode C++《热题 Hot 100-18》538.把二叉搜索树转换为累加树
查看>>
Leetcode C++《热题 Hot 100-19》543.二叉树的直径
查看>>
Leetcode C++《热题 Hot 100-21》581.最短无序连续子数组
查看>>
Leetcode C++《热题 Hot 100-22》2.两数相加
查看>>
Leetcode C++《热题 Hot 100-23》3.无重复字符的最长子串
查看>>
Leetcode C++《热题 Hot 100-24》5.最长回文子串
查看>>
Leetcode C++《热题 Hot 100-26》15.三数之和
查看>>
Leetcode C++《热题 Hot 100-28》19.删除链表的倒数第N个节点
查看>>
Leetcode C++《热题 Hot 100-29》22.括号生成
查看>>
Leetcode C++《热题 Hot 100-44》102.二叉树的层次遍历
查看>>
Leetcode C++《热题 Hot 100-47》236.二叉树的最近公共祖先
查看>>
Leetcode C++《热题 Hot 100-48》406.根据身高重建队列
查看>>
《kubernetes权威指南·第四版》第二章:kubernetes安装配置指南
查看>>
Leetcode C++《热题 Hot 100-49》399.除法求值
查看>>
Leetcode C++《热题 Hot 100-51》152. 乘积最大子序列
查看>>
Leetcode C++ 《第181场周赛-1》 5364. 按既定顺序创建目标数组
查看>>
Leetcode C++ 《第181场周赛-2》 1390. 四因数
查看>>
阿里云《云原生》公开课笔记 第一章 云原生启蒙
查看>>
阿里云《云原生》公开课笔记 第二章 容器基本概念
查看>>
阿里云《云原生》公开课笔记 第三章 kubernetes核心概念
查看>>