【无标题】

1.请使用递归的方式求出斐波那契数1,1,2,3,5,8,13..给你一个整数n,求出它的值是多少?


public class abc{
    public static void main(String[] args) {
        T t = new T();
        int n =7;
        int res =t.fibonacci(n);
        if (res != -1) {
            System.out.println("当n=7对应的斐波那契数=" + res);
        }
    }
}

class T {
    /*
     请使用递归的方式求出斐波那契数 1,1,2,3,5,8,13...给你一个整数 n,求出它的值是多
      思路分析
     1. 当 n = 1 斐波那契数 是 1
     2. 当 n = 2 斐波那契数 是 1
     3. 当 n >= 3 斐波那契数 是前两个数的和
     4. 这里就是一个递归的思路
    */
    public int fibonacci(int n) {
        if (n >= 1) {
            if (n == 1 || n == 2) {
                return 1;
            } else {
                return fibonacci(n - 1) + fibonacci(n - 2);
            }
        }else {
            System.out.println("要求输入的n>=1的整数");
            return -1;
        }
    }
}

2.猴子吃桃子问题:有一堆桃子,猴子第一天吃了其中的一半,并再多吃了一个!以后
每天猴子都吃其中的一半,然后再多吃一个。当到第10天时,想再吃时(即还没吃),
发现只有1个桃子了。问题:最初共多少个桃子?
 

public class abc{
    public static void main(String[] args) {
        T t = new T();
        int day = 1;
        int peachNum = t.peach(day);
        if(peachNum != -1) {
            System.out.println("第 " + day + "天有" + peachNum + "个桃子");
        }
        }
    }

class T {
    /*
 猴子吃桃子问题:有一堆桃子,猴子第一天吃了其中的一半,并再多吃了一个!
 以后每天猴子都吃其中的一半,然后再多吃一个。当到第 10 天时,
 想再吃时(即还没吃),发现只有 1 个桃子了。问题:最初共多少个桃子?
 思路分析 逆推
 1. day = 10 时 有 1 个桃子
 2. day = 9 时 有 (day10 + 1) * 2 = 4
 3. day = 8 时 有 (day9 + 1) * 2 = 10
 4. 规律就是 前一天的桃子 = (后一天的桃子 + 1) *2//就是我们的能力
 5. 递归
 */
    public int peach(int day) {
        if(day == 10) {//第 10 天,只有 1 个桃
            return 1;
        } else if ( day >= 1 && day <=9 ) {
            return (peach(day + 1) + 1) * 2;//规则,自己要想
        } else {
            System.out.println("day 在 1-10");
            return -1;
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值