济南学习 Day 5 T2 pm
逆欧拉函数(arc)
题目描述:
已知phi(N),求N。
输入说明:
两个正整数,分别表示phi(N)和K。
输出说明:
按升序输出满足条件的最小的K个N。
样例输入:
8 4
杨丽输出:
15 16 20 24
数据范围:
对于20%的数据 phi(N)<=100
对于40%的数据 phi(N)<=10^5
对于80%的数据 phi(N)<=10^9
对于100%的数据 phi(N)<=10^14,K<=1000
其中有60%的数据满足K=1
输入数据保证符合题意,且满足答案中最大的数不超过10^14。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<ctime>
#define ll long long
using namespace std;
const ll N=1e7;
const ll M=1e5+;
ll n,k,tot,prime[N/],ans[M];
bool check[N+];
void prepare()
{
ll x=min(N,n*);
for(ll i=,t;i<=x;i++)
{
if(!check[i]) prime[++tot]=i;
for(ll j=;j<=tot&&(t=prime[j]*i)<=x;j++)
{
check[t]=;
if(i%prime[j]==) break;
}
}
}
ll mul(ll x,ll y,ll z)
{
ll r=;
for(;y;x<<=,x%=z,y>>=)
{
if(y&)
r+=x,r%=z,y--;
}
}
ll Qc(ll x,ll y,ll z)
{
ll r=;
for(;y;x<<=,x%=z,y>>=)
if(y&)
r=mul(r,x,z);
return r;
}
bool is_prime(ll n)
{
if(n<) return ;
if(n==) return ;
if(!(n&)) return ;
ll m=n-,j=;
for(;!(m%);j++,m>>=);
for(ll a,x,y,i=;i<=;i++)
{
a=rand()%(n-)+;
x=Qc(a,m,n);
for(ll k=;k<=j;k++){
y=mul(x,x,n);
if(y==&&x!=&&x!=n-) return ;
x=y;
}
if(x!=) return ;
}
return ;
}
void dfs(ll x,ll y,ll z)
{
if(x==)
{
ans[++ans[]]=y;return;
}
if(z<=) return;
if(x+>prime[tot]&&is_prime(x+)) ans[++ans[]]=y*(x+);
for(ll a,b,c,i=z;i;i--)
{
if(x%(prime[i]-)==)
{
a=x/(prime[i]-);b=y;c=;
while(a%c==)
{
b*=prime[i];
dfs(a/c,b,i-);
c*=prime[i];
}
}
}
}
int main()
{
srand(time());
scanf("%I64d%I64d",&n,&k);
prepare();
dfs(n,,tot);
sort(ans+,ans+ans[]+);
for(int i=;i<=k;i++)
printf("I64d ",ans[i]);
return ;
}
思路:
|
算法一 |
暴力枚举N,暴力求出phi(N)验证答案。 |
|
|
时间复杂度:O(N^1.5)或O(N^2logN)或O(N^(5/4)logN) |
期望得分:20-50 |
|
|
算法二 |
在算法一的基础上,求phi用欧拉线性筛法。 |
|
|
时间复杂度:O(N) |
期望得分:50 |
|
|
算法三 |
考虑到原数只可能有一个大于10^7的质因子。考虑将phi(N)分解,在10^7范围内从大到小暴力搜索质因子试除(从大到小搜索可使状态树上紧下宽),并记录对应的N。一个明显的优化就是如果当前数加一为大于10^7的一个质数(用Miller-Rabin素性测试判)就可以停止这一状态的继续搜索了。虽然看起来复杂度很吓人,不过由于满足条件的N较少等等种种原因,实测还是相当快的。 |
|
|
时间复杂度:O(?) |
期望得分:100 |
|
济南学习 Day 5 T2 pm的更多相关文章
- 济南学习 Day 3 T2 pm
LYK 快跑!(run)Time Limit:5000ms Memory Limit:64MB题目描述LYK 陷进了一个迷宫! 这个迷宫是网格图形状的. LYK 一开始在(1,1)位置, 出口在(n, ...
- 济南学习 Day 2 T2 pm
她[问题描述]给你L,R,S,M,求满足L≤ (S × x) mod M ≤ R最小的正整数 X.[输入格式]第一行一个数T代表数据组数.接下来一行每行四个数代表该组数据的L,R,S,M.[输出格式] ...
- 济南学习 Day 5 T1 pm
欧拉函数(phi)题目描述: 已知(N),求phi(N). 输入说明: 正整数N. 输出说明: 输出phi(N). 样例输入: 8 样例输出: 4 数据范围: 对于20%的数据,N<=10^5 ...
- 济南学习 Day 4 T1 pm
幸运数字(number)Time Limit:1000ms Memory Limit:64MB题目描述LYK 最近运气很差,例如在 NOIP 初赛中仅仅考了 90 分,刚刚卡进复赛,于是它决定使用一些 ...
- 济南学习 Day 4 T2 am
LYK 与实验室(lab)Time Limit:5000ms Memory Limit:64MB题目描述LYK 在一幢大楼里,这幢大楼共有 n 层,LYK 初始时在第 a 层上.这幢大楼有一个秘密实验 ...
- 济南学习 Day 3 T3 pm
仙人掌(cactus)Time Limit:1000ms Memory Limit:64MB题目描述LYK 在冲刺清华集训(THUSC) !于是它开始研究仙人掌,它想来和你一起分享它最近研究的结果. ...
- 济南学习 Day 3 T1 pm
巧克力棒(chocolate)Time Limit:1000ms Memory Limit:64MB题目描述LYK 找到了一根巧克力棒,但是这根巧克力棒太长了,LYK 无法一口吞进去.具体地,这根巧克 ...
- 济南学习 Day 3 T2 am
看程序写结果(program)Time Limit:1000ms Memory Limit:64MB题目描述LYK 最近在准备 NOIP2017 的初赛,它最不擅长的就是看程序写结果了,因此它拼命地在 ...
- 济南学习 Day 2 T3 pm
它[问题描述]N个人坐成一圈,其中第K个人拿着一个球.每次每个人会以一定的概率向左边的人和右边的人传球.当所有人都拿到过球之后,最后一个拿到球的人即为胜者.求第N个人获胜的概率. (所有人按照编号逆时 ...
随机推荐
- Python学习日志9月15日
一周就要过去了,而我跟一周以前没什么区别.回想一下,我这周做了什么事情呢.恍然若失.这周的精力都浪费在很多不必要的事情上了.学过一片古文,讲后羿学射箭,他有一个同学跟他一样聪明,在一起学习.后羿呢,专 ...
- Python 元组、字典、集合操作总结
元组 a=('a',) a=('a','b') 特点 有序 不可变,不可以修改元组的值,无法为元组增加或者删除元素 元组的创建 a=('a',) a=('a','b') tuple('abcd') 转 ...
- 设置windows status bar隐藏
info.plist View controller-based status bar appearance 为 NO CGContextSaveGState: invalid context 0x0 ...
- myna代码
https://github.com/TalkingData/Myna/tree/master/Dataset https://github.com/TalkingData/Myna
- shell补充知识点
一.cut(截取) 1.按字节截取(-b) 例:/etc/passwd文件截取 head -5 passwd | cut -b 1-4 ----->截取1-4的字节 head -5 passwd ...
- CPP-基础:内部函数应该在当前源文件中说明和定义
static函数与普通函数作用域不同,仅在本文件.只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义.对于可在当前源文件以外使用的函数,应该在一个头文件 ...
- 基于docker搭建wordpress博客网站平台
WordPress是使用PHP语言开发的博客平台,用户可以在支持PHP和MySQL数据库的服务器上架设属于自己的网站.也可以把 WordPress当作一个内容管理系统(CMS)来使用. WordPre ...
- 实验十一 团队作业7:团队项目设计完善&编码
实验十一 团队作业7:团队项目设计完善&编码 实验时间 2019-6-6 Deadline: 2019-6-12 10:00,以团队随笔博文提交至班级博客的时间为准. 评分标准: 按时交 – ...
- EOF与feof
在C语言中,或更精确地说成C标准函数库中表示文件结束符(end of file).在while循环中以EOF作为文件结束标志,这种以EOF作为文件结束标志的文件,必须是文本文件.在文本文件中,数据都是 ...
- Eclipse调试:项目在Debug模式下,无法启动的问题
问题:Eclipse中调试Java项目时,使用正常模式:Run 项目名,可以正常启动.当想打断点调试时,点击Debug按钮后,项目显示 Source not found,或者弹出窗口显示服务器在45秒 ...