day23-递归练习/集合练习

23.01_File类递归练习(统计该文件夹大小)

  • 需求:1,从键盘接收一个文件夹路径,统计该文件夹大小
/**
 * 统计文件夹大小
 */
public static long getFileLength(File file) {
    long length = 0;
    for (File f : file.listFiles()) {
        if (f.isFile()) {
            length += f.length();
        }else {  //文件夹就递归
            length += getFileLength(f);  
        }
    }
    return length ;
}

/**
 * 键盘录入文件夹路径
 * @return 文件夹路径
 */
public static File getDir() {
    Scanner sc = new Scanner(System.in);
    System.out.println("请输入文件夹路径...");
    
    while(true) {
        File file = new File(sc.nextLine());
        if (!file.exists()) {  //是否存在路径或文件
            System.out.println("路径不存在,请重新输入...");
            continue;
        } else if(file.isFile()) { //是文件,就以当前文件所在文件夹为目标文件夹
            sc.close();
            return file.getParentFile();
        } else {
            sc.close();
            return file ;
        }
    }
}

long size = getFileLength(getDir());
float t = (float) (size / 1024.0 / 1024.0 / 1024.0);
DecimalFormat df = new DecimalFormat("#.##");    //四舍五入保留小数
System.out.println("文件夹大小是: " + df.format(t) + "GB");
System.out.println("文件夹大小是: " + t + "字节");

23.02_File类递归练习(删除该文件夹)

  • 需求:2,从键盘接收一个文件夹路径,删除该文件夹
/**
 * 删除文件夹
 * @param file 文件夹路径
 */
public static void deleteFile(File file) {
    for (File f : file.listFiles()) {  //如果文件夹不是空的,那么delete()是删不掉的,
        if (f.isFile()) {
            f.delete();  //文件就直接删除
        } else {
            deleteFile(f);  //递归删除文件夹子内容
        }
    }
    file.delete();
}

23.03_File类递归练习(拷贝)

  • 需求:3,从键盘接收两个文件夹路径,把其中一个文件夹中(包含内容)拷贝到另一个文件夹中
/**
 * 将path1文件内的子内容拷贝到path2文件夹内
 * @param initPath 源文件夹路径
 * @param path1 源文件夹路径
 * @param path2 目标文件夹
 * @throws IOException
 */
public static void copyFile(String initPath, File path1, File path2) throws IOException {
    if (path1.equals(path2)) return ; //防止相同文件夹造成死循环
    
    for (File subFile : path1.listFiles()) {
        if (subFile.isFile()) {  // 是否文件直接拷贝
            // 处理路径问题,拷贝过去,要求层级目录不变
            String path = subFile.getPath();
            String sp = path.substring(initPath.length()); //得到文件的层级结构
            File newDir = new File(path2.getPath() + sp).getParentFile();
            if (!newDir.exists()) {  //在新文件夹下,建立层级结构
                newDir.mkdirs();
            }
            FileInputStream fis = new FileInputStream(subFile);
            FileOutputStream fos = new FileOutputStream(path2.getPath() + sp);
            
            byte[] data = new byte[1024 * 10];
            int len ;
            while( (len = fis.read(data)) != -1) {
                fos.write(data, 0, len);
            }
            
            fis.close();
            fos.close();
        } else {  // 文件夹就递归
            copyFile(initPath, subFile, path2);
        }
    }
}

23.04_File类递归练习(按层级打印)

  • 需求:4,从键盘接收一个文件夹路径,把文件夹中的所有文件以及文件夹的名字按层级打印
/**
 * 按层级结构打印文件夹目录
 * @param file 文件夹路径
 * @param lev 递归计数器,调用时,必须传入0
 */
public static void printFile(File file , int lev) {
    for ( File subFile : file.listFiles() ) {
        
        for(int i = 0 ; i < lev ; i++) { //打印层级结构,这种思路很巧妙
            System.out.print("\t");
        }
        System.out.println(subFile); //无论是文件还是文件夹,都需要直接打印
        
        if (subFile.isDirectory()) {  //是文件夹就递归
            printFile(subFile, lev+1); //这里不能 ++ 运算符,思考一下为什么
        }
    }
}

23.05_递归练习(斐波那契数列)

  • 不死神兔
    故事得从西元1202年说起,话说有一位意大利青年,名叫斐波那契。在他的一部著作中提出了一个有趣的问题:假设一对刚出生的小兔一个月后就能长成大兔,再过一个月就能生下一对小兔,并且此后每个月都生一对小兔,一年内没有发生死亡,
  • 问:一对刚出生的兔子,一年内繁殖成多少对兔子?
  • 兔子数量增长数列: 1 1 2 3 5 8 13...
// 方法二: 递归解决
public static int fun(int mou) {  // mou为任意月份,返回此月份的兔子数量
    if (mou == 1 || mou == 2) {
        return 1 ;
    }
    return fun(mou - 2) + fun(mou - 1) ;
}

// 方法一: 数组解决
public static void demo1() {
    int[] arr = new int[12];  //长度就是多少个月份
    arr[0] = 1;  //根据数列规律,前2个数的和就是第三个的数,而前2个数确定是1
    arr[1] = 1;
    
    // 遍历数组,对其他月份赋值
    for (int i = 2; i < arr.length; i++) {
        arr[i] = arr[i-1] + arr[i-2]; 
    }
    
    System.out.println(arr[12]);
}

23.06_递归练习(1000的阶乘所有零和尾部零的个数)

  • 需求:求出1000的阶乘所有零和尾部零的个数,不用递归做
BigInteger bi1 = new BigInteger("1");
for(int i = 1 ; i <= 1000 ; i++) {
    BigInteger bi2 = new BigInteger(i+"");
    bi1 = bi1.multiply(bi2); //将 bi1 和 bi2的结果相乘再赋值给bi1
}
String str = bi1.toString();
int count = 0 ;
for (char c : str.toCharArray()) {
    if ('0' == c) count++ ;
}
System.out.println("所有零的个数:" + count);

// 字符串反转 (链式编程),最好记住下面的方法
str = new StringBuilder(str).reverse().toString();
int num= 0 ;
for(char c : str.toCharArray()) {
    if('0' != c) break ;
    num++;
}
System.out.println("尾部零的个数:" + num);

23.07_递归练习(1000的阶乘尾部零的个数)

  • 需求:求出1000的阶乘尾部零的个数,用递归做
public static int fun(int num) {
    if (num > 0 && num < 5) {
        return 0;
    } else {
        return num / 5 + fun(num / 5);
    }
}
// 推导过程十分麻烦,百度吧,比如下面链接的讲解
http://blog.csdn.net/yahohi/article/details/7528803

23.08_集合练习(约瑟夫环)

  • 幸运数字
/**
 * 约瑟夫环,幸运数字
 * @param num 人数,多少人进约瑟夫环游戏
 * @return 最后那个幸运的人的位置
 */
public static int getLuckNum(int num) {
    ArrayList<Integer> list = new ArrayList<>();  
    for (int i = 1; i <= num; i++) { //将1...num个元素存储到集合里
        list.add(i);
    }
    
    int count = 1 ;  //用来数数,计算器,只要是3的倍数就杀人
    for(int i = 0; list.size() != 1 ; i++) {  //只要集合人数不是1,就循环杀人
        if (i == list.size()) i = 0 ; //到数组末尾,就重新从头开始遍历
        if (count % 3 == 0) list.remove(i--);  //如果是3的倍数,就杀人。,--是因为数组元素减少了,索引也要跟着减少
        count++;
    }
    return list.get(0);
}

END。
我是小侯爷。
在魔都艰苦奋斗,白天是上班族,晚上是知识服务工作者。
如果读完觉得有收获的话,记得关注和点赞哦。
非要打赏的话,我也是不会拒绝的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,465评论 25 707
  • Ubuntu的发音 Ubuntu,源于非洲祖鲁人和科萨人的语言,发作 oo-boon-too 的音。了解发音是有意...
    萤火虫de梦阅读 99,138评论 9 467
  • 1 IONo18 1.1IO框架 【 IO:Input Output 在程序运行的过程中,可能需要对一些设备进...
    征程_Journey阅读 948评论 0 1
  • 初中开始,就对省外的世界充满幻想。大概觉得自己与众不同,别人不愿意去的地方偏要走一遭,不愿意走的路硬是要踩一遍。高...
    鬼扯少女阅读 279评论 1 3
  • 天沐王朝京都繁华热闹,街面商铺林立,往来人群不断,你走在大街上随手拉过一人,问他可知道京都四美?那人定能头头事道...
    山水叶子阅读 161评论 0 0