[英]Converting Binary Number to Decimal using recursion technique
如标题所述,我正在尝试使用Java中的递归技术将二进制转换为十进制,但我无法获得所需的输出,这就是我所做的
public class deci {
public static void main(String args[]){
hexa s1=new deci();
s1.spawn(11000);
}
void spawn(int a){
int p=0;int x=0;int k=0;
if(a>0){
p=a%10;
x=x+p*(int)Math.pow(2,k);
k++;
spawn(a/10);
} else {
System.out.print(x);
}
}
}
问题是您没有使用spawn的结果,无论是返回还是打印它。
如果要退回它,则需要移动或移动电源,但是要打印它。
我建议您逐步调试程序中的代码,以便了解它在做什么。
这是一个工作程序。
参数为(二进制代码,代码1的大小),例如对于(111,2),它将返回7
int binaryToDecimal(int binary,int size){
if(binary==0) return 0;
return binary%10*(int)Math.pow(2,size)+binaryToDecimal((int)binary/10,size-1);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.