唯⼀分解定理表明,每个⼤于1的⾃然数可以唯⼀地写成若⼲个质数的乘积。下⾯函数将⾃然数 的所有质因 数找出来,横线上能填写的最佳代码是( )。
#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)
正确答案:D