淦编一点也不美. 阶乘

Q1. 给定一个整数N,那么N的阶乘N!末尾有多少个0?例如:N = 10, N! = 362880, N!末尾有2个0。

Q2.求N!的二进制表示中最低位1的位置。

Q1 Thinking:

对于N = 10 时,末尾0的个数就是N!可以整除几个10,而阶乘N = 2^x + 3^y + 5^z....,觉得末尾0个数的关键在于x和z的个数,即min(x, z),又因为在阶乘中2出现的概率要远大于5,所以实际上末尾0的个数为5。

Q1 Code:

void rear_num(int n)
{
    int num = 0;
    for(int i = 0; i < n; i++)
    {
        int j = i;
        while(j % 5 == 0)
        {
            num++;
            j /= 5;
        }
    }
    cout << "number 0 in the rear of have " << num << endl;
}

Q2 Thinking:

因为N! = 2^x + 4^y + 8^z.....,因此最低位1的位置等于x。 对于一个二进制数除以2,若最后一位为0,则二进制位右移1位,若最后一位为1,则表示该数为奇数,无法被2整除,所以问题最后等同于求N!含有质因数2的个数。

Q2 Code:

void lowest_one(int n)
{
    int num = 0;
    while(n)
    {
        n >>= 1;
        num++;
    }
    cout << "number 1 lowest postion is" << num << endl;
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值