用javascript写的一个求补码的函数,欢迎指正
有两个参数,输出二进制值。len是输出值的长度。还有输入数据有效性没有处理,比如数据溢出处理,非数字值处理。
// 补码转换函数
function complementCode(n,len)
{ var cc = "";//补码
var Num = Number(trim(n));
var aBit = "";
var countFor1=0;
var absNum = Math.abs(Num);
var Num2 = absNum.toString(2);//转换成二进制
//alert("Num2="+Num2+" len="+len);
while(Num2.length<len-1){//不足位数补0
Num2 = "0" + Num2;
}
//判断正负数
if (Num <0){//负数
for(var i=Num2.length;i>0;i--){
aBit = Num2.substring(i-1,i);
//alert("i="+i+" aBit="+aBit);
if(countFor1 >= 1){
cc = (1^aBit) + cc;
}else{
if(aBit == "1"){ countFor1=countFor1+1;}
cc = aBit + cc;
}
}
cc = "1"+cc; //补标志位
}else{//整数的补码不变
cc = "0"+Num2; //补标志位
}
return cc;
}