76.递归
Posted 江小白谢
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了76.递归相关的知识,希望对你有一定的参考价值。
递归:函数自身调用函数自身
使用递归的前提是要有条件结束这个自身调用(不然会出现死循环)
public class Demo1 { public static void main(String[] args) { File file = new File("D:\新建文件夹"); System.out.println(print1(5)); print2(file,""); myDelete(file); } //计算出5的阶层(5*4*3*2*1) public static int print1(int num) { if(num==1) { return 1; }else { return num*print1(num-1); } } //打印文件夹的路径 public static void print2(File file,String str) { //根据传入的路径获取所有文件 File[] allFile = file.listFiles(); //根据是文件夹还是文件不同的处理 for (File itemp : allFile) { if(itemp.isFile()) { System.out.println(str+itemp.getName()); }else if(itemp.isDirectory()) { System.out.println(str+itemp.getName()); print2(itemp,"--"+str); } } } //因为delete只能删除一个空的文件夹,所以我们可以根据递归删除所有文件 public static void myDelete(File file) { //根据传入的路径获取所有文件 File[] allFile = file.listFiles(); //根据是文件夹还是文件不同的处理 for (File itemp : allFile) { if(itemp.isFile()) { itemp.delete(); }else if(itemp.isDirectory()) { myDelete(itemp); } file.delete(); } } }
以上是关于76.递归的主要内容,如果未能解决你的问题,请参考以下文章
JavaScript - 代码片段,Snippets,Gist