【BZOJ4803】逆欧拉函数
【BZOJ4803】逆欧拉函数
题面
题解
题目是给定你\(\varphi(n)\)要求前\(k\)小的\(n\)。
设\(n=\prod_{i=1}^k{p_i}^{c_i}\)
则\(\varphi(n)=\prod_{i=1}^k{p_i}^{c_i-1}(p_i-1)\)
然后我们猜一下这个\(n\)不是很多,事实上\(n\)不超过\(50w\)个。
考虑暴力\(dfs\)出所有的\(n\):
首先筛出\(\sqrt{\varphi(n)}\)内的素数
对于当前\(dfs\)的值\(phi\)
看\(phi\)中的约数有没有\(筛出的素数-1\)
若有,假设该素数为\(p\)
去除\(phi\)中的所有\(p\),之后再将\(dfs\)的\(n\)累乘上\(p\)
在每一次递归开头用\(miller\)_\(Rabin\)判断\(phi+1\)是否为素数,如果是,则直接加进答案就行了
想一想,为什么?
代码
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <ctime>
using namespace std;
typedef long long ll;
const int MAX_N = 1e7 + 5;
const int T = 10;
bool is_prime[MAX_N];
int prime[MAX_N], num, K;
ll N = 1e7, ans[MAX_N], cnt_ans;
void sieve() {
for (int i = 1; i <= N; i++) is_prime[i] = 1;
is_prime[1] = 0;
for (int i = 2; i <= N; i++) {
if (is_prime[i]) prime[++num] = i;
for (int j = 1; prime[j] * i <= N && j <= num; j++) {
is_prime[i * prime[j]] = 0;
if (!(i % prime[j])) break;
}
}
}
ll fmul(ll x, ll y, ll Mod) {
ll res = 0;
while (y) {
if (y & 1ll) res = (res + x) % Mod;
y >>= 1ll;
x = (x + x) % Mod;
}
return res;
}
ll fpow(ll x, ll y, ll Mod) {
ll res = 1;
while (y) {
if (y & 1ll) res = fmul(res, x, Mod);
y >>= 1ll;
x = fmul(x, x, Mod);
}
return res;
}
bool Test(ll a, ll n) {
ll r = 0, t = n - 1, m;
while ((t & 1ll) == 0) ++r, t >>= 1ll;
m = (n - 1) / (1ll << r);
for (int i = 0; i < r; i++) if (fpow(a, (1ll << i) * m, n) == n - 1) return 1;
if (fpow(a, m, n) == 1) return 1;
return 0;
}
bool Miller_Rabin(ll n) {
if (n == 2ll) return 1;
if (n < 2ll || ((n & 1ll) == 0)) return 0;
for (int i = 1; i <= T; i++) {
ll a = rand() % (n - 2) + 2;
if (fpow(a, n - 1, n) != 1) return 0;
if (!Test(a, n)) return 0;
}
return 1;
}
void solve(ll phi, ll n, int lst) {
if (phi + 1 > prime[num] && Miller_Rabin(phi + 1))
ans[++cnt_ans] = n * (phi + 1);
for (int i = lst; i; i--) {
if (!(phi % (prime[i] - 1))) {
ll t1 = phi / (prime[i] - 1), t2 = n, t3 = 1ll;
while (!(t1 % t3)) {
t2 *= prime[i];
solve(t1 / t3, t2, i - 1);
t3 *= prime[i];
}
}
}
if (phi == 1ll) ans[++cnt_ans] = n;
}
int main () {
srand(time(NULL));
sieve();
cin >> N >> K;
solve(N, 1ll, num);
sort(&ans[1], &ans[cnt_ans + 1]);
for (int i = 1; i < K; i++) printf("%lld ", ans[i]);
printf("%lld\n", ans[K]);
return 0;
}
【BZOJ4803】逆欧拉函数的更多相关文章
- 求逆欧拉函数(arc)
已知欧拉函数计算公式 初始公式:φ(n)=n*(1-1/p1)*(1-1/p2).....*(1-1/pm) 又 n=p1^a1*p2^a2*...*ps^as 欧拉函数是积性函数 那么:φ(n ...
- now code——小a和黄金街道(欧拉函数和快速幂模板)
小a和小b来到了一条布满了黄金的街道上.它们想要带几块黄金回去,然而这里的城管担心他们拿走的太多,于是要求小a和小b通过做一个游戏来决定最后得到的黄金的数量.游戏规则是这样的:假设道路长度为米(左端点 ...
- UVA10200-Prime Time/HDU2161-Primes,例题讲解,牛逼的费马小定理和欧拉函数判素数。
10200 - Prime Time 此题极坑(本菜太弱),鉴定完毕,9遍过. 题意:很简单的求一个区间 ...
- hdu2588 GCD (欧拉函数)
GCD 题意:输入N,M(2<=N<=1000000000, 1<=M<=N), 设1<=X<=N,求使gcd(X,N)>=M的X的个数. (文末有题) 知 ...
- BZOJ 2705: [SDOI2012]Longge的问题 [欧拉函数]
2705: [SDOI2012]Longge的问题 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 2553 Solved: 1565[Submit][ ...
- BZOJ 2818: Gcd [欧拉函数 质数 线性筛]【学习笔记】
2818: Gcd Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 4436 Solved: 1957[Submit][Status][Discuss ...
- COGS2531. [HZOI 2016]函数的美 打表+欧拉函数
题目:http://cogs.pw/cogs/problem/problem.php?pid=2533 这道题考察打表观察规律. 发现对f的定义实际是递归式的 f(n,k) = f(0,f(n-1,k ...
- poj2478 Farey Sequence (欧拉函数)
Farey Sequence 题意:给定一个数n,求在[1,n]这个范围内两两互质的数的个数.(转化为给定一个数n,比n小且与n互质的数的个数) 知识点: 欧拉函数: 普通求法: int Euler( ...
- 51Nod-1136 欧拉函数
51Nod: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1136 1136 欧拉函数 基准时间限制:1 秒 空间限制: ...
随机推荐
- 关于crontab中的一些小问题
今天写了个脚本,要写进crontab做定时任务,每5分钟跑一遍.关于crontab的介绍呢,请大家移步www.baidu.com,在这里我就不仔细介绍了.可以搜索一下“每天一个Linux命令”系列文章 ...
- BZOJ2330:[SCOI2011]糖果(差分约束)
Description 幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比他的 ...
- 3171. [TJOI2013]循环格【费用流】
Description 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为(0,0).给定一个起始位置(r,c) ,你可以沿着箭头防线在格 ...
- Odoo中的模型
转载请注明原文地址:https://www.cnblogs.com/cnodoo/p/9280164.html [Odoo中,一切皆模型,连视图都是模型.Odoo将各种数据,如:权限数据 ...
- 2、Web Service-术语
1.Java中的Web Service规范 三种规范:JAXM&SAAJ.JAX-WS(JAX-RPC).JAX-RS. 三要素:soap,wsdl,uddi 1. Jaxws(掌握) JAX ...
- ethereumjs/ethereumjs-block-1-简介
https://github.com/ethereumjs/ethereumjs-block Encoding, decoding and validation of Ethereum's Block ...
- 新闻cms管理系统(三) ------菜单管理
1.前期准备工作 (1)模板介绍 添加菜单的模板页面 菜单管理首页: 添加菜单页面: (2)公共类引入介绍 公共函数文件的引入(位置: Application/Admin/Controller/Com ...
- Loadrunner之HTTP脚本编写
Loadrunner之HTTP脚本编写 刚学习性能测试的时候还是建议以录制脚本为好,从录制的脚本中去了解脚本结构,各个函数的用法,慢慢再去尝试自己去编写脚本,如果想往技术方向发展,建议最好学习一门编程 ...
- Linux TCP server 只能接受一个 TCP 连接
#include <stdio.h> #include <sys/types.h> #include <sys/socket.h> #include <str ...
- 我的QT5学习之路(二)——第一个程序
一.前言 “工欲善其事,必先利其器”,上一节,我介绍了Qt的安装和配置方法,搭建了基本的开发平台.这一节,来通过一个简单的例子来了解Qt的编程样式和规范,开始喽~~~ 二.第一个程序——Hello W ...