假设我们需要列出四个数字 A、B、C、D。A+B+C+D 的和为 10,每个数字的值在 [0, 10] 范围内。
找出所有可能的组合。
蛮力方式如下:
for (int A = 0; A <=10; ++A)
for (int B = 0; B <=10-A; ++B)
{
if (A + B > 10) break;
for (int C = 0; C <=10-A-B; ++C)
{
if (A + B + C > 10) break;
for (int D = 0; D <=10-A-B-C; ++D)
{
if (A + B + C + D == 10)
{
cout << "A: " << A << ",B: " << B << ",C: " << C << ",D: " << D << endl;
break;
}
else if (A + B + C + D > 10)
break;
}
}
}
Q> 有没有更好的解决方案?
仅供参考:根据@rici 的建议更新代码