整数划分 java_java – 将整数划分为k个部分

这个想法是一种回溯算法方法(带递归),您可以减少参数并得到局部解决方案,然后检查您是否有正确的解决方案.

public class Problem {

private static void algorithm(int n, int k, int m) {

algorithmRecursive(Collections.EMPTY_LIST, n, k, m, 1);

}

private static void algorithmRecursive(List partial, int n, int k, int m, int min) {

if ( (k > 0) ) {

// Optimization

if ((n <= k * m) && (n >= k*min)){

for (int i = min; i <= Math.min(m, n); i++) {

List newPartial = new ArrayList<>(partial);

newPartial.add(i);

algorithmRecursive(newPartial, n - i, k - 1, m, i);

}

}

} else if (n == 0) {

// Right solution

System.out.println(partial);

}

}

public static void main(String[] args) {

algorithm(7,4,3);

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值