[算法]求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;
}

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

相关推荐
立志成为大牛的小牛2 分钟前
数据结构——十七、线索二叉树找前驱与后继(王道408)
数据结构·笔记·学习·程序人生·考研·算法
星空下的曙光4 分钟前
Node.js crypto模块所有 API 详解 + 常用 API + 使用场景
算法·node.js·哈希算法
阳光雨滴18 分钟前
使用wpf用户控件编程落石效果动画
c++·wpf
小贾要学习1 小时前
【数据结构】C++实现红黑树
数据结构·c++
ajassi20001 小时前
开源 C++ QT QML 开发(十七)进程--LocalSocket
c++·qt·开源
StarPrayers.2 小时前
旅行商问题(TSP)(2)(heuristics.py)(TSP 的两种贪心启发式算法实现)
前端·人工智能·python·算法·pycharm·启发式算法
微露清风2 小时前
系统性学习C++-第五讲-内存管理
java·c++·学习
爱吃橘的橘猫2 小时前
嵌入式系统与嵌入式 C 语言(2)
c语言·算法·嵌入式
235162 小时前
【LeetCode】146. LRU 缓存
java·后端·算法·leetcode·链表·缓存·职场和发展
星夜钢琴手3 小时前
推荐的 Visual Studio 2026 Insider C++ 程序项目属性配置
c++·visual studio