[算法]求n!在m进制下末尾有多少个0

参考链接:求n!在m进制下末尾0的个数_.!零n,,m-CSDN博客

我们这里和参考链接不同

使用结构体去存储每个因数的信息

然后使用变量index作为索引,其最终值为因数的个数

具体原理:

例子1:求9!在10进制下的末尾的0的个数

思考1:在10进制下出现0,必须是质数2 与 5组合,所以统计2和5作为因数出现了多少次,取最小的数量就是答案

例子2:求10!在9进制下的末尾的0的个数

思考2:在9进制出现0,其必然是两个3组合起来才会在9进制出现0结尾,所以统计所有因子里面各自出现的次数(这里只有3)然后 整除以 对应因子在进制9里面出现的次数 取最小的那一个值 即是答案!

下面给出一个例题和题解

例题:Contest1035 - NewOJ 2022 Contest 7 - New Online Judge (ecustacm.cn)

题解:

cpp 复制代码
#include<iostream>

using namespace std;
#define debug(x) cout<<#x<<" : "<<x<<endl;
typedef long long int ll;

const int maxLine=10010; 
struct primeInfo {
	int nums;
	int counts;
};
void getPrime(int m);
void printPrimeArray(struct primeInfo arr[maxLine],int len);
int countDivision(int n,int p);

struct primeInfo  myPrime[maxLine];
// 记录数量和下标 
int index=0;
int res=0x3f3f3f3f;
int main(){
	int n,m;
//	cin>>n>>m;
	n=20;
	m=14; 
	getPrime(m);
//	printPrimeArray(myPrime,index);
	for(int i=0;i<index;i++){
		res=min(res,countDivision(n,myPrime[i].nums)/myPrime[i].counts);
	}
	cout<<res;
	return  0;
} 
// 获取素数个数 
void getPrime(int m){
	for(int i=2;i*i<=m;i++){
		// 统计当前因数的个数和具体数值	
		while(m%i==0){
			myPrime[index].nums=i;
			myPrime[index].counts++;
			m/=i;
		}
		if(myPrime[index].counts!=0) index++; 
	}	
	//如果是合数 那么会在之前统计完
	//如果是质数 那么本身这个质因数统计不到
	if (m>1) myPrime[index].nums=m,myPrime[index++].counts++; 
}
// 打印查看 
void printPrimeArray(struct primeInfo arr[maxLine],int len){
	for(int i=0;i<len;i++){
		cout<<i<<": "<<arr[i].nums<<" "<<arr[i].counts<<endl;
	}
}
int countDivision(int n,int p){
	// 只要不包含1这个参数就一定会结束循环 
//	cout<<"传入参数"<<n<<" "<<p<<endl;
	int counts=0;
//	debug(counts);
	while(n>0){
		counts+=n/p;
		n/=p;
	}
//	debug(counts);
	return counts;
}

中间用到了一点点判断因数范围的小技巧,你发现了吗?

相关推荐
Miraitowa_cheems4 分钟前
LeetCode算法日记 - Day 94: 最长的斐波那契子序列的长度
java·数据结构·算法·leetcode·深度优先·动态规划
L_090713 分钟前
【Algorithm】Day-11
c++·算法·leetcode
薛慕昭40 分钟前
C语言核心技术深度解析:从内存管理到算法实现
c语言·开发语言·算法
.ZGR.43 分钟前
第十六届蓝桥杯省赛 C 组——Java题解1(链表知识点)
java·算法·链表·蓝桥杯
近津薪荼44 分钟前
每日一练 1(双指针)(单调性)
c++·算法
林太白1 小时前
八大数据结构
前端·后端·算法
爱思德学术1 小时前
第二届中欧科学家论坛暨第七届人工智能与先进制造国际会议(AIAM 2025)在德国海德堡成功举办
人工智能·算法·机器学习·语言模型
机器学习之心1 小时前
MATLAB多子种群混沌自适应哈里斯鹰算法优化BP神经网络回归预测
神经网络·算法·matlab
qq_479875432 小时前
C++ ODR
java·开发语言·c++
MicroTech20252 小时前
微算法科技(NASDAQ MLGO)“自适应委托权益证明DPoS”模型:重塑区块链治理新格局
科技·算法·区块链