几道递归的经典习题

1.递归求N的阶乘

public static int fac(int num) {
        if(num == 1 ) {
            return num;
    }
    return num*fac(num-1);
    }
    public static void main(String[] args) {
        Scanner scan =new Scanner(System.in);
        int num = scan.nextInt();
        System.out.println(fac(num));
    }

2.递归求1+2+3+…+10

public static int sum(int num) {
    if(num == 1) {
        return num;
    }
    return num+sum(num-1);
    }
    public static void main(String[] args) {
        int num = 10;
        System.out.println(sum(num));
    }

3.按顺序打印一个数的每一位(例如1234打印出1 2 3 4)

public static void orderPrint(int num) {
        if(num > 9) {
            orderPrint(num/10);
        }
        System.out.println(num%10);
    }
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        orderPrint(num);
    }

4.写个递归方法,输入一个非负整数,返回组成它的数字之和

public static int sumNumber(int num) {
        if(num <10) {
            return (num%10);
        }
    return num%10+sumNumber(num/10);
    }
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        System.out.println(sumNumber(num));
    }

5.求菲波那契数列的第N项

public static int fibonacci1(int num) {
        if(num <= 2) {
            return 1;
        }
        return fibonacci1(num-1)+fibonacci1(num-2);
    }
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        System.out.println(fibonacci1(num));
    }
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值