质因子在数论里指能整除给定正整数的质数,例如100的质因子就是2、2、5、5. 要求编写程序,用户输入一个正整数,输出其所有的质因子。注意:输入只能使用scanf()或cin函数,使用其他输入函数不得分。
时间: 2024-10-24 07:14:33 浏览: 40
在 C++ 中,要编写一个程序来找出给定正整数的质因子,你可以使用以下步骤:
1. 定义一个辅助函数 `isPrime` 来检查一个数是否为质数。
2. 创建主函数 `main`,接收用户输入的正整数。
3. 使用循环从 2 开始(因为最小的质数是 2),直到输入的数除以当前数没有余数为止。这个循环找到的因子都是质数。
4. 如果当前数是质数并且它是输入数的因子,将其打印出来。
下面是相应的 C++ 代码实现:
```cpp
#include <iostream>
// 辅助函数:检查一个数是否为质数
bool isPrime(int num) {
if (num <= 1)
return false;
for (int i = 2; i * i <= num; i++) {
if (num % i == 0)
return false;
}
return true;
}
// 主函数:找出并打印质因子
void findPrimeFactors(int n) {
std::cout << "质因数有: ";
for (int i = 2; i * i <= n; i++) { // 从2开始到根号n,寻找因子
while (n % i == 0 && isPrime(i)) { // 只保留质因子
std::cout << i << " ";
n /= i;
}
}
// 检查 n 是否大于 1(如果原数是完全平方数,可能最后一个因子没有被打印)
if (n > 1 && isPrime(n))
std::cout << n << " ";
}
int main() {
int inputNumber;
std::cout << "请输入一个正整数: ";
scanf("%d", &inputNumber);
findPrimeFactors(inputNumber);
std::cout << "\n";
return 0;
}
```
阅读全文