C语言--正整数质因式分解

输入:一个正整数
输出:对其进行质因式分解。例如,输入90,打印出90=2*3*3*5

实现

需要注意的是,给出的示例中有*3*3,同一个因子可能多次使用,因此要使用while来除

void primeFactorization(int n) {
  for(int i=2;i<=n;i++){
    while(n!=i){
      if(n%i==0){
        printf("%d*", i);
        n=n/i;
      }else{
        break;
      }
    }
  }
  printf("%d\n", n);
}
int main() {
  int n;
  scanf("%d", &n);
  printf("%d=", n);
  primeFactorization(n);
  return 0;
}

测试

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

优化

上面的代码虽然能正确分解,但当n已经是质数时,无法停止循环,存在冗余遍历,效率低下。
例如:输入n=7(质数)时:
i从2递增到7,每次while(n != i)条件不成立。
循环结束后打印n=7,输出7=7(虽然结果正确,但是冗余遍历了2-7的过程)。

当i > sqrt(n)时,剩余n必为质数,可直接终止循环。

void primeFactorization2(int n) {
  if (n == 1) {
    printf("1\n");
    return ;
  }
  int isFirst = 1; // 标记是不是首个因数
  for (int i=2; i*i <= n;i++) { // 减少循环次数
    while (n%i == 0) {
      if (isFirst) {
        printf("%d", i);
        isFirst = 0;
      } else {
        printf("*%d", i);
      }
      n /= i;
    }
  }
  // 处理剩余的大于1的质因数
  if (n>1) {
    if (isFirst) {
      printf("%d", n); // n本身是质数
    } else {
      printf("*%d", n);
    }
  }
  printf("\n");
}

运行

与上面一样,不多余贴图了
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小雅痞

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

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

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

打赏作者

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

抵扣说明:

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

余额充值