第23618题
质因数分解函数中空缺处应填入的最佳代码是

唯一分解定理表明,每个大于1的自然数可以唯一地写成若干个质数的乘积。下面函数将自然数 n的所有质因数找出来,横线上能填写的最佳代码是( )。

#include <vector>
vector<int> get_prime_factors(int n) {
    vector<int> factors;
    if (n <= 1) {
        cout << "输入的数必须是大于1的正整数" << endl;
        return;
    }
    while (n % 2 == 0) {
        factors.push_back(2);
        n /= 2;
    }

__________________________  {    // 在此处填入代码
        while (n % i == 0) {
            factors.push_back(i);
            n /= i;
        }
    }
    if (n > 2) {
        factors.push_back(n);
    }

    return factors;
}
A

for (int i = 3; i <= n; i ++)

B

for (int i = 3; i * i <= n; i ++)

C

for (int i = 3; i <= n; i += 2)

D

for (int i = 3; i * i <= n; i += 2)

提交0次 正确率0.00%
答案解析