XYNUOJ1847: 阶乘因式分解(二)

1847: 阶乘因式分解(二)

时间限制: 3 Sec 内存限制: 64 MB
提交: 67 解决: 53
您该题的状态:已完成
[提交][状态][讨论版]

题目描述

给定两个数n,m,其中m是一个素数。
将n(0<=n<=2^31)的阶乘分解质因数,求其中有多少个m。
注:^为求幂符号。

输入

第一行是一个整数s(0<s<=100),表示测试数据的组数
随后的s行, 每行有两个整数n,m。

输出

输出m的个数

样例输入

3
100 5
16 2
1000000000 13

样例输出

24
15
83333329

#include<iostream>
#include<cmath>
using namespace std;
int main(){
	int a,n,m;
	cin>>a;
	while(a--){
		int sum=0;
		cin>>n>>m;
		while(m<=n){
			sum += n/m;
			n /= m;
		}
		cout<<sum<<endl;
	}
	return 0;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章