1. 递归算法解题步骤
(1) 分析问题、寻找递归关系。找出大规模问题和小规模问题的关系。
(2) 找出停止条件,控制递归。
(3) 设计函数、确定参数。
(1) 分析问题、寻找递归关系。找出大规模问题和小规模问题的关系。
(2) 找出停止条件,控制递归。
(3) 设计函数、确定参数。
- *阶乘的例子。其实递归递归,从字面上解释就是在方法本身调用自己的方法,或者间接调用;看上面的程序,拿multiply(5)来说:
- *n=5;执行5*multiply(4);
- *--------------------
- *这时候看multiply(4)
- n=4执行4*multiply(3);
- -------------------
- 看multiply(3)
- n=3,执行3*multiply(2);
- ---------------
- mulitply(2);
- n=2执行2*mulitply(1);
- 这时候,return1;往上返回
- 2*1向上返回
- 3*(2*1)向上返回
- 4*(3*(2*1))向上返回
- 5*(4*(3*(2*1)))=120
- 所以程序输出120;S
- 这事简单的递归的例子;所以可以看出来递归的关键得有递归出口(本体的If语句),还有递归方法
- *@paramn
- *@return
- */
- publicstaticintmultiply(intn){
- if(n==0){
- return1;
- }else{
- returnn*(multiply(n-1));
- }
- }
- /**
- *计算二进制中1的个数,
- *N为奇数,其1的个数等于N/2二进制中表示1的个数加1
- *例子:
- *num=13
- *1.getBinary(13/2=6)+1;调用getBinary(6/2=3)+1返回2+1=3
- *2.getBinary(6/2=3);进入方法,调用getBinary(1)+1=2;
- *3.getBinary(1)+1;getBinary(1)返回1,getBinary(1)+1实际返回2
- *从步骤3返回1+1;
- *再返回到步骤2,没有做运算
- *再返回到步骤1
- *@paramnum
- *@return
- */
- publicstaticintgetBinary(intnum){
- if(num==1)
- return1;
- if(0==num%2){//是否为偶数
- returngetBinary(num/2);
- }else{
- returngetBinary(num/2)+1;
- }
- }
- /**
- *利用位移来解决n>>1右移一位,相当与n/2
- *@paramn
- *@return
- */
- publicstaticintgetBinary2(intn){
- if(n==0){
- returnn;
- }
- //为偶数
- if(n%2==0){
- returngetBinary2(n>>1);
- }else{
- //若N是奇数...等于N/2的二进制中1的个数加1
- returngetBinary2(n>>1)+1;
- }
- }