码迷,mamicode.com
首页 > 其他好文 > 详细

76.递归

时间:2018-06-01 15:28:10      阅读:88      评论:0      收藏:0      [点我收藏+]

标签:bubuko   let   int   mil   http   技术分享   src   dir   分享   

递归:函数自身调用函数自身

使用递归的前提是要有条件结束这个自身调用(不然会出现死循环)

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.递归

标签:bubuko   let   int   mil   http   技术分享   src   dir   分享   

原文地址:https://www.cnblogs.com/zjdbk/p/9121625.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!