今天早上突然心血来潮决定用 ''和js来撸一个进制转换.(纯属心血来潮,有兴趣的可以看看.)

我们知道,通过8421码.可以快速的得到一个10进制的2进制.如下图:

如上图所示:我们将10进制的 '10'转换成2进制,

10=8+2; 那么8421码下面的8和2用1表示,4和1用0表示;则可以得到1010;这个1010便是10的二进制数.是不是很简答呢?

再来一个栗子:

.

到这里你可能会疑问,那如果是大于15呢(8+4+2+1完全不够用啊)?

很简单啊,8421不够那就168421 再不够就 ......1024,512,256,128,64,32.....1 ;

OK,到此为止我们知道如果通过8421码得到一个数的2进制.那么 代码走起

======================================================================

1,若数字对应8421则用1表示,否则用0;

    function toBinary (num) {
//存储结果的数组
var arr = [];
var _8421 = [8,4,2,1];
var fn = function(num){
for(var i=0;i<_8421.length;i++) {
var temp = num-_8421[i];
if(temp == 0){
arr.push(1);
}else{
arr.push(0);
}
}
return arr;
}; //返回fn得到返回的数组,并去除前面的0
return fn(num).join('').replace(/^0+/,'');
} console.log(toBinary(1)); //
console.log(toBinary(2)); //
console.log(toBinary(3)); // ''
console.log(toBinary(5)); // ''

2.上面的代码我们判断改数与8421中值的差值,如果等于0则用1表示,否则用0.但是问题来了:如果该数字不在8421中返回值就为空.想一想,除了等于0,还有大于0和小于0没有做判断.

考虑到这三种情况我们需要做:

  1: 如果差值为0,那么直接返回改数组.剩余的位用0补齐,

  2: 如果差值小于0,在用0表示改位的同时需要判断是否全部为0,如果是则返回该数组

  3: 如果差值大于0:那么在用1表示改位的同时,需要把差值再次循环判断(递归),且8421数组应从当前位截断

代码如下:

  

 function toBinary (num) {
//存储结果的数组
var arr = [];
var _8421 = [8,4,2,1];
//二进制位数
var bit = _8421.length;
//判断数组值是否全为0
var isAll0 = function(arr){
var flag = true;
for(var i=0;i<bit;i++){
if(arr[i] != 0){
flag = false;
continue;
}
}
return flag;
};
var fn = function(num){
for(var i=0;i<_8421.length;i++){
//存放8421的临时值
var temp = _8421[i];
//如果传入的数字与8421数组中相减为0
if(num-temp == 0){
//该位用1表示
arr.push(1);
var length = arr.length;
//如果当前输入length小于bit位则用0补齐
if(length<bit){
for(var c = 0;c<bit-length;c++){
arr.push(0);
}
}
return arr;
}else{
//如果小于0 则用0表示
if(num-temp<0){
arr.push(0);
//当数组长度==二进制位数的时候判断是否全部为0
if(arr.length==bit){
if(isAll0(arr)){
//返回该数组
return arr;
}
}
//如果大于0 则用1表示
}else if(num-temp>0){
arr.push(1);
//并且把8421数组从当前位索引截断
_8421.splice(0,i+1);
//把改数与当前位的差递归
return fn(num-temp);
} }
}
}; return fn(num).join('').replace(/^0+/,'')
} console.log(toBinary(1)); //
console.log(toBinary(2)); //
console.log(toBinary(3)); //
console.log(toBinary(5)); //

3:通过判断三种情况.我们正确的得到了二进制数,但是还有问题;如果输入的值很大,而我们的数组只有8421.被固定死了.也就是说现在只能得到8+4+2+1 15以内的二进制值.如果大于这个值则无法计算.

一开始想的是,扩大这个数组.例如扩大到2048.但是问题又来了.大于2048+....+.的和又出问题了.于是我们需要一个函数动态创建8421码的数组:

 var create8421 = function(num){
var tempArr = [1];
while(tempArr[0]-num<0){
//如果两数相减为负数
//在数组第一位插入第二位的2倍值
tempArr.unshift(tempArr[0]*2);
}
return tempArr; };

这个函数接收一个num.并初始化一个tempArr=[1]作为8421的基准,然判断数组第一位和num的差值.如果小于0则向该数组第一位插入第二位2倍的数;这样即可得到一个由num控制大小的8421数组

最终代码如下:

 function toBinary (num) {
var arr = [];
//根据输入的数创建对应大小的8421数组
var create8421 = function(){
var tempArr = [1];
while(tempArr[0]-num<0){
//如果两数相减为负数
//在数组第一位插入第二位的2倍值
tempArr.unshift(tempArr[0]*2);
}
return tempArr; };
var _8421 = create8421();
var bit = _8421.length;
//判断数组值是否全为0
var isAll0 = function(arr){
var flag = true;
for(var i=0;i<bit;i++){
if(arr[i] != 0){
flag = false;
continue;
}
}
return flag;
};
var fn = function(num){
for(var i=0;i<_8421.length;i++){
//存放8421的临时值
var temp = _8421[i];
//如果传入的数字与8421数组中相减为0
if(num-temp == 0){
//改位用1表示
arr.push(1);
var length = arr.length;
//如果当前输入length小于bit位则用0补齐
if(length<bit){
for(var c = 0;c<bit-length;c++){
arr.push(0);
}
}
return arr;
}else{
//如果小于0 则用0表示
if(num-temp<0){
arr.push(0);
if(arr.length==bit){
//如果8位全是0则返回改数组
if(isAll0(arr)){
return arr;
}
}
//如果大于0 则用1表示
}else if(num-temp>0){
arr.push(1);
//并且把8421数组从当前位索引截断
_8421.splice(0,i+1);
//把改数与当前位的差递归
return fn(num-temp);
} }
}
}; return fn(num).join('').replace(/^0+/,'') } console.log(toBinary(77)); //
console.log(toBinary(156)); //
console.log(toBinary(5369)); //
console.log(toBinary(66666)); //
console.log(toBinary(233333)); //

这样一个用'8421'码转换 进制的代码便完成了.

其实有个小问题:如果输入0的话直接给返回" ".原因是因为正则替换掉了0.来个正则大神讲解下:如果只有1一个0则保留0,否则替换由'0'开始的所有0;

代码写得有点粗糙.没有考虑太多.新手发文,求大神轻喷 = =#!

欢迎吐槽代码,指出错误.

<!--

作者:mgso
出处:http://www.cnblogs.com/mgso/p/6181095.html
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。谢谢合作。

-->

js用8421码实现10进制转2进制的更多相关文章

  1. 16进制字符串和byte数组进行相互转换\将10进制转换为任意进制

    16进制字符串和byte数组进行相互转换 简介 1个byte对应8个bit,16进制使用4个bit,所以一个byte转成16进制,占用两位. JAVA代码 private static final c ...

  2. C++ 中 int 转string, 以及10进制转2进制

    感谢:http://blog.csdn.net/xiaofei2010/article/details/7434737 以及:http://www.cnblogs.com/nzbbody/p/3504 ...

  3. python中2进制、10进制、16进制等之间的转换

    10转2: bin(8) # '0b1000' 2转10: int( 10转16: hex(15) # '0xf' 16转10: int( 2进制和16进制中间通过转10进制可以相互转换 from b ...

  4. javascript 10进制和64进制的转换

    原文:javascript 10进制和64进制的转换 function string10to64(number) { var chars = '0123456789abcdefghigklmnopqr ...

  5. c# 关于10进制和16进制转换以及显示

    直接举例说明: int i = 15;//一个10进制数 string txt = Convert.ToString(i,16);//将上面10进制以16进制形式显示为f string s = &qu ...

  6. python3 第十九章 - 写一个10进制转任意进制的函数

    我们先回忆下之前所学的进制转换的知识(详见:第十章),10进制转其它进制的方法是: 整数部分,除基取余,逆序排列 小数部分,乘基取整,顺序排列 负数,按绝对值处理 好,假设我们需要转化的数都是正整数, ...

  7. 10进制 VS 2进制

    10进制 VS 2进制 时间限制: 1 Sec  内存限制: 32 MB 题目描述 样例输出 623 #include<stdio.h> #include<string.h> ...

  8. js便签笔记(10) - 分享:json2.js源码解读笔记

    1. 如何理解“json” 首先应该意识到,json是一种数据转换格式,既然是个“格式”,就是个抽象的东西.它不是js对象,也不是字符串,它只是一种格式,一种规定而已. 这个格式规定了如何将js对象转 ...

  9. 题目1208:10进制 VS 2进制(进制转换以及大数保存问题)

    题目链接:http://ac.jobdu.com/problem.php?pid=1208 详细链接:https://github.com/zpfbuaa/JobduInCPlusPlus 参考代码: ...

随机推荐

  1. itextpdf JAVA 输出PDF文档

    使用JAVA生成PDF的时候,还是有些注意事项需要处理的. 第一.中文问题,默认的itext是不支持中文的,想要支持,需要做些处理. 1.直接引用操作系统的中文字体库支持,由于此方案限制性强,又绑定了 ...

  2. Bulk Insert的用法 .

    /******* 导出到excel */EXEC master..xp_cmdshell 'bcp SettleDB.dbo.shanghu out c:/temp1.xls -c -q -S&quo ...

  3. 重构第1天:封装集合(Encapsulate Collection)

    理解:封装集合就是把集合进行封装,只提供调用者所需要的功能行借口,保证集合的安全性. 详解:在大多的时候,我们没有必要把所有的操作暴露给调用者,只需要把调用者需要的相关操作暴露给他,这种情况中下我们就 ...

  4. [转载]斐讯K2 A2版免TTL刷BREED不死Bootloader

    1:路由器能正常上网,登陆进路由器 (默认密码admin) 2:用浏览器打开这个网址,如果默认ip不是192.168.2.1修改一下.打开后等待即可自动刷入breed. http://192.168. ...

  5. Changing Project Binding to Surround SCM Integration Provider with Visual Studio 2010

    Changing Project Binding to Surround SCM Integration Provider with Visual Studio 2010 Sarah Wigser t ...

  6. SharePoint 2010中重置windows 活动目录(AD)域用户密码的WebPart(免费下载)

    由于SharePoint 2013推出不久,并非所有的企业都会升级到SharePoint 2013的,毕竟升级不是打打补丁这么简单,更多的企业还是使用Sharepoint 2010版本的,因此本人自行 ...

  7. cakePHP的controller回调

    1. afterFilter(), executed after all controller logic, including the rendering of the view2. beforeF ...

  8. Python Shell 解释器下使用Django Model

    sys.path.append('E:/Projects/DjangoProjects/myFirstSite') os.environ.setdefault('DJANGO_SETTINGS_MOD ...

  9. 转:C#中String类的几个方法(IndexOf、LastIndexOf、Substring)

    String.IndexOf String.IndexOf 方法 (Char, Int32, Int32)报告指定字符在此实例中的第一个匹配项的索引.搜索从指定字符位置开始,并检查指定数量的字符位置. ...

  10. 未能找到类型或命名空间名称“Coco”(是否缺少 using 指令或程序集引用)

    未能找到类型或命名空间名称"Coco"(是否缺少 using 指令或程序集引用),如果你确实引用了,那说明你引用的和你的项目环境版本不一样,.NET framework的问题,修改 ...