[PA 2017] Iloczyn 题解

题目连接

题意

给定一组质数,且有一个正整数集合,该集合中的所有数不超过 n n n ,且其中每个数的质因子分解仅包含这些给定的质数。求该集合中的最大的数为多少。

思路

考虑深搜。依次枚举质数集中的每一个数,若与当前乘积相乘后依然不大于 n n n 就继续搜索。注意每个数可以乘多次,代码如下:

cpp 复制代码
void dfs(int x,ll z){
	ans=max(ans,z);
	if(x>k)return;
	for(ll tmp=z;n/tmp>=p[x];)
		tmp*=p[x],dfs(x+1,tmp);
	dfs(x+1,z);
}

但光是这样会 TLE ,所以要考虑优化:

优化1:排序

不难发现,只要将这些质数降序排列,就可以在前期得到较大解。

优化2:剪枝

加上这么一行代码,就能让你的代码变快很多:

cpp 复制代码
if(ans/z==n/z)return;

为什么呢?假设当前乘积为 z z z ,当 ⌊ n / z ⌋ = ⌊ a n s / z ⌋ \left \lfloor n/z \right \rfloor=\left \lfloor ans/z\right \rfloor ⌊n/z⌋=⌊ans/z⌋ 时,根据整数除法的性质:

  • 存在整数 k k k 使得: k = ⌊ n / z ⌋ = ⌊ a n s / z ⌋ k =\left \lfloor n/ z\right \rfloor =\left \lfloor ans/ z\right \rfloor k=⌊n/z⌋=⌊ans/z⌋ ;

  • 这意味着: k z ≤ n < ( k + 1 ) z kz \le n < (k+1)z kz≤n<(k+1)z 且 k z ≤ a n s < ( k + 1 ) z kz \le ans < (k+1)z kz≤ans<(k+1)z !

由于两者除以 z z z 的商相等,说明当前乘积 z z z 已经达到了一个临界点:在 z z z 的基础上,无论再怎么乘(使用剩余的质数),得到的结果除以 z z z 的商最多只能是 k k k 。

完整代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define ll unsigned long long
const int N=30;
int k,p[N];
ll n,ans=1;
void dfs(int x,ll z){
	ans=max(ans,z);
	if(x>k)return;
	if(ans/z==n/z)return;
	for(ll tmp=z;n/tmp>=p[x];)
		tmp*=p[x],dfs(x+1,tmp);
	dfs(x+1,z);
}
int main(){
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	cin>>k>>n;
	for(int i=1;i<=k;i++)cin>>p[i];
	sort(p+1,p+k+1,greater<int>());
	dfs(1,1),cout<<ans;
	return 0;
}

AC记录

相关推荐
czy87874754 小时前
深入了解 C++ 中的 `std::bind` 函数
开发语言·c++
我在人间贩卖青春4 小时前
C++之继承的方式
c++·private·public·protected·继承方式
智者知已应修善业5 小时前
【洛谷P9975奶牛被病毒传染最少数量推导,导出多样例】2025-2-26
c语言·c++·经验分享·笔记·算法·推荐算法
Trouvaille ~6 小时前
【Linux】应用层协议设计实战(一):自定义协议与网络计算器
linux·运维·服务器·网络·c++·http·应用层协议
CSCN新手听安6 小时前
【linux】高级IO,I/O多路转接之poll,接口和原理讲解,poll版本的TCP服务器
linux·运维·服务器·c++·计算机网络·高级io·poll
CSCN新手听安6 小时前
【linux】网络基础(三)TCP服务端网络版本计算器的优化,Json的使用,服务器守护进程化daemon,重谈OSI七层模型
linux·服务器·网络·c++·tcp/ip·json
m0_736919106 小时前
C++中的委托构造函数
开发语言·c++·算法
小小小小王王王6 小时前
洛谷-P1886 【模板】单调队列 / 滑动窗口
c++·算法
历程里程碑6 小时前
Linux 库
java·linux·运维·服务器·数据结构·c++·算法
Sheep Shaun6 小时前
如何让一个进程诞生、工作、终止并等待回收?——探索Linux进程控制与Shell的诞生
linux·服务器·数据结构·c++·算法·shell·进程控制