c++ 质因数的个数

当计算一个数的质因数个数时,可以考虑以下更细致和全面的C++代码示例:

#include <iostream>

#include <vector>

// 函数用于计算一个数的质因数个数,并返回质因数的向量

std::vector<int> calculatePrimeFactors(int n) {

    std::vector<int> primeFactors;

   

    // 尝试将n除以2,直到它不再是偶数

    while (n % 2 == 0) {

        primeFactors.push_back(2);

        n /= 2;

    }

   

    // 现在n是奇数,循环从3开始,尝试将n除以小于等于n的奇数因数

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

        while (n % i == 0) { // i是n的因数

            primeFactors.push_back(i);

            n /= i; // 除以i,继续寻找下一个因数

        }

    }

   

    // 如果n大于2,说明n是一个质数

    if (n > 2)

        primeFactors.push_back(n);

   

    return primeFactors;

}

int main() {

    int num;

    std::cout << "请输入一个正整数:";

    std::cin >> num;

   

    std::vector<int> primeFactors = calculatePrimeFactors(num);

   

    std::cout << "质因数的个数为:" << primeFactors.size() << std::endl;

    std::cout << "质因数分别为:";

    for (int factor : primeFactors) {

        std::cout << factor << " ";

    }

    std::cout << std::endl;

   

    return 0;

}

在上述代码中,calculatePrimeFactors函数计算给定数字n的质因数,并将质因数存储在向量primeFactors中。函数首先尝试将n除以2,直到它不再是偶数。然后,使用循环从3开始,尝试将n除以小于等于n的奇数因数,直到n变为质数。在循环的每一步,如果某个数i是n的因数,将其添加到primeFactors向量,并将n除以i以继续寻找下一个因数。最后,如果n大于2,则说明n本身是一个质数,也将其添加到primeFactors向量中。

在main函数中,用户被要求输入一个正整数,并调用calculatePrimeFactors函数计算其质因数。然后,输出质因数的个数以及每个质因数的值。

这个示例代码更全面地处理了质因数的情况,包括了偶数因子2,并在循环条件中使用了平方根优化,以减少迭代次数。同时,将质因数存储在向量中,方便进一步处理和使用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南抖北快东卫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值