计算 1000!的末尾有多少个零

该程序通过遍历从5到1000的5的倍数,统计5的因子数量来确定1000!的尾部0的个数。由于每个0由2和5的因子配对产生,而2的因子明显多于5,因此只需要关注5的因子。最终结果是所有5的因子数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

编写程序计算1000!的某尾有多少个0

#include <stdio.h>
int main(int argc, char const *argv[])
{
  int i, k, m;
  k = 0;
  for (i = 5; i <= 1000; i = i + 5)
  {
    m = i;
    while (m % 5 == 0) // 含有一个5因子
    {
      k++;
      m = m / 5;
    }
  }
  printf("%d", k);
  return 0;
}

结尾的每一个0都表示有一个因数10存在。

10可以分解为2 × 5,因此只有质数2和5相乘能产生0,别的任何两个质数相乘都不能产生0,而且2,5相乘只产生一个0。

分解后的整个因数式中有多少对(2, 5),结果中就有多少个0,而分解的结果中,2的个数显然是多于5的,因此,考虑有多少个5即可。

所以遍历1~1000,分别访问5/10/15....,求出每个数会产生多少个5因子即可。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

会不了一点

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

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

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

打赏作者

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

抵扣说明:

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

余额充值