洛谷 P11045 [蓝桥杯 2024 省 Java B] 最优分组

Problem Discription\] \\color{blue}{\\texttt{\[Problem Discription\]}} \[Problem Discription

Analysis\] \\color{blue}{\\texttt{\[Analysis\]}} \[Analysis

首先得注意这么一点: k k k 必须得是 n n n 的因数(这里的 n , k n,k n,k 对应于题目的 N , K N,K N,K),不然不合法。

其实这虽然是限制,但是这个限制其实是使得题目的难度大大降低了。因为这样每组的宠物数量相同,有完全相同的规律,不需要特殊讨论。

每组 k k k 只宠物,一共需要分成 c = n k c=\dfrac{n}{k} c=kn 组。

对于每组宠物,假设被感染的宠物数量为 x x x。调动我们残存的高中知识,我们惊喜地发现, x x x 服从二项分布。于是我们知道 E ( x ) = k p E(x)=kp E(x)=kp。

但是这并没有什么用。我们需要知道的是有宠物感染病毒的概率。正难则反,没有宠物感染病毒的概率是 p k p^{k} pk,所以有宠物感染病毒的概率就是 ( 1 − p k ) \left ( 1 - p^{k} \right ) (1−pk)。

一旦有动物感染,就需要重新进行 k k k 次测试。于是每一组测试次数的期望值是 k + k × ( 1 − p k ) k+k \times \left (1 - p^{k} \right ) k+k×(1−pk)。

一共有 c c c 组,由期望的线性可加性知,总的期望即为 n × [ k + k × ( 1 − p k ) ] n \times \left [ k + k \times \left ( 1 - p^{k} \right ) \right ] n×[k+k×(1−pk)],化简即为 n k + n × ( 1 − p k ) nk+n \times \left ( 1 - p^{k} \right ) nk+n×(1−pk)。

一个快速幂,加上枚举即可。总时间复杂度 O ( n log ⁡ n ) O(n \log n) O(nlogn)。不过这个时间复杂度好像有点问题?反正就是线性对数就对了。

另外:不要忘记特判 k = 1 k=1 k=1 的情况。 k = 1 k=1 k=1 时的检测次数就是 n n n!!!

Code \color{blue}{\text{Code}} Code

cpp 复制代码
int n,ans;double p,minn;

double ksm(double u,int v){
	快速幂自己写,太简单啦
}

double f(int k){
	return n/k+n*(1-ksm(1-p,k));
}

int main(){
	cin>>n>>p;
	
	minn=n;ans=1;//特判 k=1
	
	for(int i=2;i<=n;i++)
		if (n%i==0){
			double tmp=f(i);
			
			if (tmp<minn){
				minn=tmp;
				ans=i;
			}
		}
	
	printf("%d",ans);
	
	return 0;
}
相关推荐
消失的旧时光-194323 分钟前
智能指针(三):实现篇 —— shared_ptr 的内部设计与引用计数机制
java·c++·c·shared_ptr
黄昏晓x30 分钟前
C++----哈希表
c++·哈希算法·散列表
三月微暖寻春笋1 小时前
【和春笋一起学C++】(六十一)公有继承中的多态
c++·多态·virtual·基类·虚函数·公有继承
兩尛2 小时前
409. 最长回文串
c++·算法·leetcode
智者知已应修善业2 小时前
【pta反转加法构造回文数c语言1000位】2025-1-31
c语言·c++·经验分享·笔记·算法
List<String> error_P2 小时前
蓝桥杯基础知识点:模拟-数位操作类题目
python·算法·蓝桥杯
汉克老师2 小时前
GESP2024年3月认证C++二级( 第三部分编程题(2)小杨的日字矩阵 )
c++·矩阵·循环结构·gesp二级·gesp2级·打印图形
yyjtx3 小时前
DHU上机打卡D27
c++·算法·图论
白太岁3 小时前
C++:(5) 单例模式与支持初始化失败的单例模式
c++·单例模式
hwtwhy3 小时前
【情人节特辑】C 语言实现浪漫心形粒子动画(EasyX 图形库)
c语言·开发语言·c++·学习·算法