fxhbeyond 2012-07-06 16:52
浏览 230
已采纳

求教一个算法

现在有n种楼,每种楼的面积已知,给定一个地块,地块总面积已知,要求每种楼摆多少个能满足总面积小于地块面积并且此地块不能再放楼的所有组合

  • 写回答

2条回答 默认 最新

  • feizhuzi 2012-07-09 12:23
    关注

    [code="java"]

    public class Demo {

    public static void main(String[] args) {
    
        //第一二三种楼的面积分别为 3 7 11, 假设是整数
        int[] bAreas = {3, 7, 11};
        //某块地的面积
        int availArea = 228;
        //上一次的结果
        int[] result = new int[bAreas.length];
        //收集结果
        List<int[]> list = new ArrayList<int[]>();
        //计算
        calc(bAreas, availArea, 0, result, list);
        //打印结果
        for (int[] is : list) {
            for (int i : is) {
                System.out.print(i + " ");
            }
            System.out.println();
        }
    }
    
    public static void calc(int[] bAreas, int availArea, int from, final int[] lastResult, List<int[]> list) {
        //楼的种类数
        int countOfKind = bAreas.length;
        //剩余面积
        int leftArea = availArea;
        //结果
        int[] result = Arrays.copyOf(lastResult, countOfKind);
    
        for (int i = from; i < countOfKind; i++) {
            int bArea = bAreas[i];
            int bCount = leftArea / bArea;
            result[i] = bCount;
            leftArea = leftArea % bArea;
    
    
            //递归
            int recursionTimes = bCount;
            int nextLeftArea = leftArea;
            int[] nextResut = Arrays.copyOf(result, countOfKind);
            while( (i != countOfKind - 1) && recursionTimes > 0){
                nextLeftArea += bArea;
                nextResut[i] = --recursionTimes;
                calc(bAreas, nextLeftArea, i+1, nextResut, list);
            }
    
        }
        list.add(result);
    }
    

    }

    [/code]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 求学软件的前人们指明方向🥺
  • ¥50 如何增强飞上天的树莓派的热点信号强度,以使得笔记本可以在地面实现远程桌面连接
  • ¥15 MCNP里如何定义多个源?
  • ¥20 双层网络上信息-疾病传播
  • ¥50 paddlepaddle pinn
  • ¥20 idea运行测试代码报错问题
  • ¥15 网络监控:网络故障告警通知
  • ¥15 django项目运行报编码错误
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services