博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于递归方法的实现
阅读量:6279 次
发布时间:2019-06-22

本文共 1468 字,大约阅读时间需要 4 分钟。

所谓递归(Rcursion),就是方法调用自身.对于递归来说,一定有一个出口,让递归结束,只有这样才能保证不出现死循环.

一些复杂的应用递归还是挺难的,比如在调试的时候A调用B,直接去B看就行了,但是递归的话调试的时候又去A了.对思维要求还是比较高的.

比如:n! = n * (n-1) * (n-2)......*1 另外一种思路是用递归的思想 n! =  n * (n-1) !

递归很容易出错,稍微不注意就变成死循环了.

1.计算一个数阶乘的递归算法:

1 public class Factorial2 { 2     //使用递归的方式计算阶乘 3     public static void main(String[] args) { 4         compute(5); 5     } 6     public static  int compute(int number){ 7         if(1 == number){ 8             return 1; 9         }else{10             return number * compute(number-1);11         }12     }13 }

2.用递归计算第n个斐波那契数列是几?

1 public class Factorial3 { 2     //使用递归计算斐波那契数列. 3     public static int compute(int n){ 4         //递归的出口 5         if(1==n || 2==n){ 6             return 1; 7         }else{ 8             return compute(n-1)+compute(n-2); 9         }10     }11     public static void main(String[] args) {12         System.out.println(compute(9));13     }14 }

3.用递归删除一个文件夹.

1 public class Factorial4 { 2     //用递归的方法删除文件. 3     public static void main(String[] args) { 4         deleteAll(new File("C:\\kongtest")); 5     } 6      7     public static void deleteAll(File file){ 8         //如果这个是一个文件或者不是文件(那就是个目录里面为空)中的list()返回一个数组的长度是0 9         if(file.isFile() || file.list().length == 0){10             file.delete();11         }else{12             File[] files = file.listFiles();13             for(File f:files){14                 deleteAll(f);15                 f.delete();16             }17         }18     }19 }

 

转载地址:http://xwfva.baihongyu.com/

你可能感兴趣的文章
Firefox 是 Pwn2own 2014 上攻陷次数最多的浏览器
查看>>
阿里感悟(十八)- 应届生Review
查看>>
《计算广告:互联网商业变现的市场与技术》一第一部分 在线广告市场与背景...
查看>>
话说模式匹配(5) for表达式中的模式匹配
查看>>
《锋利的SQL(第2版)》——1.7 常用函数
查看>>
《Arduino家居安全系统构建实战》——1.5 介绍用于机器学习的F
查看>>
jquery中hover()的用法。简单粗暴
查看>>
线程管理(六)等待线程的终结
查看>>
spring boot集成mongodb最简单版
查看>>
DELL EqualLogic PS存储数据恢复全过程整理
查看>>
《Node.js入门经典》一2.3 安装模块
查看>>
《Java 开发从入门到精通》—— 2.5 技术解惑
查看>>
Linux 性能诊断 perf使用指南
查看>>
实操分享:看看小白我如何第一次搭建阿里云windows服务器(Tomcat+Mysql)
查看>>
Sphinx 配置文件说明
查看>>
数据结构实践——顺序表应用
查看>>
python2.7 之centos7 安装 pip, Scrapy
查看>>
机智云开源框架初始化顺序
查看>>
Spark修炼之道(进阶篇)——Spark入门到精通:第五节 Spark编程模型(二)
查看>>
一线架构师实践指南:云时代下双活零切换的七大关键点
查看>>