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;
}