非规律化递归问题:文件搜索、啤酒问题

这篇博客探讨了两个非规律化递归问题。第一个是使用Java实现的文件搜索,通过递归遍历目录查找指定文件。第二个是啤酒问题,模拟了用啤酒瓶和瓶盖购买更多啤酒的过程,展示了递归在计算中的应用。博客中详细解释了代码逻辑并输出了结果。
摘要由CSDN通过智能技术生成

 

 非规律化递归问题:文件搜索

 

 

 

package com.gao.file;

import java.io.File;

/**
 * 利用递归来实现文件的查找
 */
public class RecursionDemo3 {
    public static void main(String[] args) {
     searchFile(new File("E:/"),"二寸照片.jpg");

    }

    private static void searchFile(File dir,String fileName) {
        //判断dir是不是目录
        if (dir !=null && dir.isDirectory()){
            //可以进行查找了
            //提取当前目录的一级文件对象
            File[] files = dir.listFiles();
            //判断是否存一级文件对象,才可以进行遍历
            if (files !=null && files.length >0){
                for (File file : files) {
                    //判断当前遍历的是一级文件还是目录
                    if (file.isFile()){
                        //判断是不是咱们要找的
                        if (file.getName().contains(fileName)){
                            System.out.println("已找到该文件" + file.getAbsolutePath());
                        }
                    }else {
                        //是文件夹 需要继续查找
                        searchFile(file, fileName);   // 这里应该从file开始接着找
                    }

                }
            }
        }else {
            System.out.println("所输入的不是文件夹,无法查找");
        }


    }
}

非规律化递归问题:啤酒问题

  

package com.gao.file;

public class ResursionDemo4 {
    public static int totalNumber;
    public static int lastBottleNumber;
    public static int lastCoverNumber;
    public static void main(String[] args) {
        buy(10);
        System.out.println("共可以买" + totalNumber + "瓶");
        System.out.println("空瓶:"+lastBottleNumber);
        System.out.println("瓶盖:"+lastCoverNumber);

    }

    private static void buy(int n) {
        //2.看可以立马买多少瓶
        int buyNumber = n / 2;
        totalNumber+=buyNumber;

//        3.把盖子和瓶子换算成钱
        // 统计本轮总盖子数 和瓶子数
        int coverNumber=lastCoverNumber+buyNumber;
        int bottleNumber=lastBottleNumber+buyNumber;

        //4.统计可以换算的钱

        int allMoney=0;
        if (coverNumber >= 4){
            allMoney+=(coverNumber / 4) * 2;
        }
        lastCoverNumber=coverNumber % 4;

        if (bottleNumber >= 2){
            allMoney+=(bottleNumber / 2) * 2;
        }
        lastBottleNumber=bottleNumber %2;
        if (allMoney >= 2) {
            buy(allMoney);
        }




    }

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值