簡體   English   中英

使用遞歸技術將二進制數轉換為十進制

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM