java中完成遞歸盤算二進制表現中1的個數。本站提示廣大學習愛好者:(java中完成遞歸盤算二進制表現中1的個數)文章只能為提供參考,不一定能成為您想要的結果。以下是java中完成遞歸盤算二進制表現中1的個數正文
借助Java說話,應用遞歸算法盤算整數N的二進制表現中1的個數
/*use the recursive algorithme to calculate * the number of "1" in the binary expression * of an Integer N. * Note:if N is an odd, then * the result is the result of N/2 plus 1. * And the program use the bit operation to * improve efficency ,though it's seemingly * not necessary ,but the idea I think is good. * The program is writed by Zewang Zhang ,at * 2015-5-4,in SYSU dorms. */ public class CalculateNumberInBinaryExpression { //Main method. public static void main(String[] args) { //For example ,make N equals 13 ,the result shows 3 System.out.println(numOfEven(13)); //For example ,make N equals 128 ,the result shows 1 System.out.println(numOfEven(128)); } //The static method of numOfEven is the recursive method. public static int numOfEven(int x) { //The base of recursive. if(x==0) { return 0; } //If x is an odd. else if(x%2!=0) { return numOfEven(x>>1)+1; } //If x is an even except 0. else { while(x%2==0) { x=(x>>1); } return numOfEven(x); } } }
來個最簡略的,不外未測試:)
public int a(int i){ if(i==0||i==1) return i; return i%2+a(i/2); }
以上所述就是本文的全體內容了,願望年夜家可以或許愛好。