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

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

相关推荐
汉克老师19 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
Yzzz-F21 小时前
Problem - 2205D - Codeforces
算法
智者知已应修善业1 天前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn1 天前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室1 天前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星1 天前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
云泽8081 天前
C++11 核心特性全解:列表初始化、右值引用与移动语义实战
开发语言·c++
科研前沿1 天前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨1 天前
1931. 用三种不同颜色为网格涂色
算法·leetcode
AI进化营-智能译站1 天前
ROS2 C++开发系列12-用多态与虚函数构建可扩展的ROS2机器人行为模块
开发语言·c++·ai·机器人