该程序用于查找数字的最小因数之和。解决这个问题的逻辑是,找到所有因素集并将它们相加。对于每组因素,我们都会做同样的事情,然后对所有因素进行比较。然后找出这些总和中的所有最小值。
Input: n=12 Output: 7
首先找到数字n的因数,然后将它们相加,并尝试最小化总和。以下是分解 12 以及因数之和的不同方法。
12 = 12 * 1 = 12 + 1 = 13 12 = 2 * 6 = 2 + 6 = 8 12 = 3 * 4 = 3 + 4 = 7 12 = 2 * 2 * 3 = 2 + 2 + 3 = 7 Therefore minimum sum is 7
#include<iostream> using namespace std; int main() { int n = 12; int sum = 0; for (int i = 2; i * i <= n; i++) { while (n % i == 0) { sum += i; n /= i; } } sum += n; cout << sum; return 0; }
以上是寻找一个数的最小因子之和的C程序?的详细内容。更多信息请关注PHP中文网其他相关文章!