问题:在一个平行宇宙中,麦当劳的麦乐鸡块分为 7 块装、13 块装和 29 块装。有一天,你的老板让你出去购买正好为 n 块(0 < n <= 10000)的麦乐鸡块回来,请提供一个算法判断是否可行。
说明:除了三重循环的解法,有没有效率更高一点的方法。求大佬指点。
问题:在一个平行宇宙中,麦当劳的麦乐鸡块分为 7 块装、13 块装和 29 块装。有一天,你的老板让你出去购买正好为 n 块(0 < n <= 10000)的麦乐鸡块回来,请提供一个算法判断是否可行。
说明:除了三重循环的解法,有没有效率更高一点的方法。求大佬指点。
function countAll(i, j, k, total) {
if ((i * 7 + j * 13 + 29 * k) > total) {
return false;
}
if (total === 7 || total === 13 || total === 29) {
return true;
}
if (isVoid(i, j, k, total)) {
return true;
} else {
return countAll(i, j, k + 1 , total) || countAll(i , j + 1, k , total) || countAll(i + 1, j , k , total) || false;
}
}
function isVoid(i, j, k, total) {
let value = i * 7 + j * 13 + 29 * k;
if (total % value == 0 && value !== 0) {
console.log(i , j , k);
return true;
}
return false;
}
var res = countAll(0, 0 , 0 ,9892);
console.log(res);
递归实现