前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LightOj 1370 欧拉筛

LightOj 1370 欧拉筛

作者头像
用户2965768
发布2019-07-31 12:02:40
3520
发布2019-07-31 12:02:40
举报
文章被收录于专栏:wymwymwym

每个长为 j 的竹子score是它的欧拉函数,费用为 j ,要找 n 个值大于或等于 score 的竹子。

求最小花费,特别地, 长度1费用为2。 素数的欧拉函数等于 它值减 1,素数的欧拉值和下标最近,找最小花费,就从

该数加一开始找第一个素数 .

//LightOj 1370 欧拉筛 
#include <iostream>
#include <algorithm>
#include <cstring>
#define ll long long
using namespace std;
const int maxn = 1e7+5;
int prime[maxn],is_prime[maxn];
int phi[maxn];
void phi_prime()
{
	memset(is_prime,0,sizeof(is_prime));
	phi[1] = 1;
	for(int i=2;i<maxn;i++){
		if(!is_prime[i]){
			prime[++prime[0]]=i;
			phi[i] = i-1;
		}
		for(int j=1;j<=prime[0]&&i*prime[j]<maxn;j++){
			is_prime[prime[j]*i]=1;
			if(i%prime[j]==0){
				phi[i*prime[j]] = phi[i]*prime[j];
				break;
			}else{
				phi[i*prime[j]] = phi[i]*(prime[j]-1);
			}
		}
	}
}
int main()
{
	phi_prime();
	int t,n,tp,cnt=1;
	scanf("%d",&t);
	while(t--){
		scanf("%d",&n);
		ll ans = 0;
		for(int i=1;i<=n;i++){
			scanf("%d",&tp);
			for(int j=tp+1;;j++){
				if(!is_prime[j]){
					ans+=j;
					break;
				}
			}
		}	
		printf("Case %d: %lld Xukha\n",cnt++,ans);
	}
	return 0;
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年07月12日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档