老程序员分享:java递归

简介: 老程序员分享:java递归

"

一 什么是递归?

递归,就是自己调用自己,但是需要给一个出口,不能无限死循环

public void method(){

System.out.println(“递归的演示”);

//在当前方法内调用自己

method();

}

递归又分直接递归和间接递归

直接递归就是在本方法中调用自己

间接递归就是A方法调用B方法,B方法调用C方法,然后C再调用A,这就是间接递归

举个例子:计算1-100之间的和

public class DiGuiDemo {

public static void main(String【】 args) {

//计算1~num的和,使用递归完成

int n = 5;

int sum = getSum(n);

//代码效果参考:https://v.youku.com/v_show/id_XNjM5NzY3NDYxNg==.html

System.out.println(sum);

}

public static int getSum(int n) {

if(n == 1){

return 1;

}

return n + getSum(n-1);

}

}

举一反三:求1-100的阶乘

public static BigDecimal getSum(int n){

BigDecimal m=new BigDecimal(n);

if(n==1){

return new BigDecimal(1);

}

BigDecimal bigMul = m.multiply(getSum(n-1));

return bigMul;

}

因为数据太大,对于大数据的处理,只能用BigDecimal

需要注意的是:

递归一定要有条件限定,保证递归能够停止下来,否则会发生栈内存溢出。

在递归中虽然有限定条件,但是递归次数不能太多。否则也会发生栈内存溢出。

二 用 递归打印所有子目录中的文件路径

public static void main(String【】 args) {

File file=new File(""E:\java"");

getFile(file);

}

public static void getFile(File dir){

File【】 files=dir.listFiles(new MyFileter());

//代码效果参考:https://v.youku.com/v_show/id_XNjQwMDE0NzYxMg==.html

System.out.println(dir+""文件夹"");

for(File f:files){

//如果该文件对象是文件夹则调用自己

if(f.isDirectory()){

getFile(f);

}

System.out.println(f);

}

}


"
image.png
相关文章
|
1天前
|
JSON Java fastjson
老程序员分享:java对象转json
老程序员分享:java对象转json
|
1天前
|
机器学习/深度学习 Java 关系型数据库
程序员必知:关于高淇JAVA中SORM总结学习笔记详细个人解释
程序员必知:关于高淇JAVA中SORM总结学习笔记详细个人解释
|
2天前
|
自然语言处理 Java 程序员
老程序员分享:Java的标识符
老程序员分享:Java的标识符
老程序员分享:Java的标识符
|
1天前
|
存储 Java
Java基础手册(标识符 关键字 字面值 变量 数据类型 字符编码 运算符 控制语句 方法及方法重载和递归 面向对象与面向过程)
Java基础手册(标识符 关键字 字面值 变量 数据类型 字符编码 运算符 控制语句 方法及方法重载和递归 面向对象与面向过程)
5 0
|
1天前
|
算法 Java 程序员
老程序员分享:Java开源
老程序员分享:Java开源
|
1天前
|
机器学习/深度学习 Java 关系型数据库
程序员必知:关于高淇JAVA中SORM总结学习笔记详细个人解释
程序员必知:关于高淇JAVA中SORM总结学习笔记详细个人解释
|
1天前
|
存储 Java 程序员
老程序员分享:Java虚拟机详解(九)
老程序员分享:Java虚拟机详解(九)
|
1天前
|
Java 程序员 容器
老程序员分享:java容器体系(三)
老程序员分享:java容器体系(三)
|
1天前
|
存储 缓存 Java
老程序员分享:Java并发编程:线程池的使用
老程序员分享:Java并发编程:线程池的使用
|
1天前
|
存储 算法 Java
老程序员分享:java之数据结构【入门篇】
老程序员分享:java之数据结构【入门篇】