c4951491235 2018-03-17 15:04 采纳率: 100%
浏览 1299
已采纳

一个算法试题,组合 (计数问题)方面

/*
X星球要派出一个5人组成的观察团前往W星。
其中:
A国最多可以派出4人。
B国最多可以派出2人。
C国最多可以派出2人。
D国最多可以派出1人。
E国最多可以派出1人。
F国最多可以派出3人。
那么最终派往W星的观察团会有多少种国别的不同组合呢?

组合问题 (计数问题)
*/
public class Main3 {

//a各个国家能派出的最大人数
//x派出方案的组合
//k选择在哪个国家派出
//goal 目标派出人数

static int sum = 0;
public static void main(String[] args) {
    int[] a = {4,2,2,1,1,3};//a-f国家有几名代表
    int[] x = new int[a.length];        
    f(a,x,0,5);
    System.out.println(sum);        
}

public static void f(int[] a,int[] x,int k,int goal) {
    if(k==x.length ) {
        if(goal == 0) {
            sum += 1;
            //return;
        }
        //return;
    }

    for(int i = 0;i <= Math.min(a[k],goal);i++ ) {
        x[k] = i;
        f(a,x,k+1,goal-i);      
    }
    x[k] = 0;

}

}

先上代码
下面是问题
在f方法中注释掉的两处的return
为什么当return在外面括号时 ,不会报错。。。
而在里面的括号时,会出现超出栈异常。。。。

他们不都是加一然后返回吗。。。

  • 写回答

2条回答 默认 最新

  • threenewbee 2018-03-17 15:34
    关注
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 Excel发现不可读取的内容
  • ¥15 UE5#if WITH_EDITOR导致打包的功能不可用
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题
  • ¥20 yolov5自定义Prune报错,如何解决?
  • ¥15 电磁场的matlab仿真
  • ¥15 mars2d在vue3中的引入问题
  • ¥50 h5唤醒支付宝并跳转至向小荷包转账界面
  • ¥15 算法题:数的划分,用记忆化DFS做WA求调
  • ¥15 chatglm-6b应用到django项目中,模型加载失败
  • ¥15 CreateBitmapFromWicBitmap内存释放问题。