【BZOJ】3737: [Pa2013]Euler
题意:
求满足\(phi(a)=n\)的\(a\)的个数。(\(n \le 10^{10}\))
分析
这种题一开始就感觉是搜索= =
题解
首先容易得到
\]
然后我们\(O(n^{0.5})\)预处理以下前\(n^{0.5}\)的素因子,然后再用\(O(n^{0.5}log(n))\)筛出大质数,然后从小到大一层一层搜下去即可,注意特判一下\(n=1\)的情况。
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll N=1e10, Lim=1e5+5, Ml=1e9;
int tot, ans, p[Lim+5], np[Lim+5], pcnt;
ll b[5000005];
struct dat {
ll p;
int l;
}a[Lim<<1];
void init() {
for(int i=2; i<=Lim; ++i) {
if(!np[i]) p[pcnt++]=i;
for(int j=0; j<pcnt; ++j) {
int t=i*p[j];
if(t>Lim) break;
np[t]=1;
if(i%p[j]==0) break;
}
}
}
ll rand(ll l, ll r) {
static ll MD=1e9+7, g=78125, now=1998;
now*=g; if(now>=MD) now%=MD;
return l+now%(r-l+1);
}
ll mul(ll a, ll b, ll m) { if(a<=Ml && b<=Ml) return a*b%m; if(b>a) swap(b, a); ll x=0; for(; b; b>>=1, a=(a+a)%m) if(b&1) x=(x+a)%m; return x; }
ll ipow(ll a, ll b, ll m) { ll x=1; for(; b; b>>=1, a=mul(a, a, m)) if(b&1) x=mul(x, a, m); return x; }
bool check(ll x) {
if(x<=Lim) return !np[x];
if((x%2)==0 || (x%3)==0 || (x%5)==0 || (x%7)==0 || (x%11)==0 || (x%13)==0) return 0;
int cnt=0; ll d=x-1; while(!(d&1)) d>>=1, ++cnt;
for(int T=0; T<=50; ++T) {
ll t=ipow(rand(2, x-1), d, x), pre=t;
for(int i=1; i<=cnt; ++i, pre=t) {
t=mul(t, t, x);
if(t==1 && pre!=1 && pre!=x-1) return 0;
}
if(t!=1) return 0;
}
return 1;
}
void pre(ll n) {
tot=0;
int sq=sqrt(n+0.5)+1;
for(int i=0; i<pcnt; ++i) {
if(p[i]>sq) break;
if(n%(p[i]-1)==0) {
ll t=n/(p[i]-1);
a[tot].p=p[i];
while(t%p[i]==0)
++a[tot].l, t/=p[i];
++tot;
}
}
for(int i=sq; i>=1; --i) if(n%i==0) {
ll pr=n/i+1; if(pr<=sq) continue;
if(check(pr))
a[tot].p=pr, a[tot++].l=0;
}
// printf("tot:%d\n", tot);
// for(int i=0; i<tot; ++i)
// printf("%lld ", a[i].p); puts("");
}
void dfs(int x, ll n, ll now) {
if(n==1) {
if(x==0) now*=2;
b[ans++]=now;
return;
}
if(x>=tot) return;
dfs(x+1, n, now);
ll pr=a[x].p;
int l=a[x].l;
if(n%(pr-1)) return;
now*=pr;
n/=pr-1;
dfs(x+1, n, now);
for(int j=0; j<l; ++j) {
if(n%pr) break;
now*=pr;
n/=pr;
dfs(x+1, n, now);
}
}
void work(ll n) {
ans=0;
dfs(0, n, 1);
printf("%d\n", ans);
sort(b, b+ans);
for(int i=0; i<ans; ++i)
printf("%lld%c", b[i], " \n"[i==ans-1]);
}
int main() {
int T; scanf("%d", &T);
init();
while(T--) {
ll n;
scanf("%lld", &n);
if(n&1) {
if(n==1) puts("2\n1 2");
else puts("0");
continue;
}
pre(n);
work(n);
}
return 0;
}
【BZOJ】3737: [Pa2013]Euler的更多相关文章
- 【BZOJ】3052: [wc2013]糖果公园
http://www.lydsy.com/JudgeOnline/problem.php?id=3052 题意:n个带颜色的点(m种),q次询问,每次询问x到y的路径上sum{w[次数]*v[颜色]} ...
- 【BZOJ】3319: 黑白树
http://www.lydsy.com/JudgeOnline/problem.php?id=3319 题意:给一棵n节点的树(n<=1e6),m个操作(m<=1e6),每次操作有两种: ...
- 【BZOJ】3319: 黑白树(并查集+特殊的技巧/-树链剖分+线段树)
http://www.lydsy.com/JudgeOnline/problem.php?id=3319 以为是模板题就复习了下hld............................. 然后n ...
- 【BZOJ】1013: [JSOI2008]球形空间产生器sphere
[BZOJ]1013: [JSOI2008]球形空间产生器sphere 题意:给n+1个n维的点的坐标,要你求出一个到这n+1个点距离相等的点的坐标: 思路:高斯消元即第i个点和第i+1个点处理出一个 ...
- 【BZOJ】1002:轮状病毒(基尔霍夫矩阵【附公式推导】或打表)
Description 轮状病毒有很多变种,所有轮状病毒的变种都是从一个轮状基产生的.一个N轮状基由圆环上N个不同的基原子和圆心处一个核原子构成的,2个原子之间的边表示这2个原子之间的信息通道.如下图 ...
- 【BZOJ】【3083】遥远的国度
树链剖分/dfs序 其实过了[BZOJ][4034][HAOI2015]T2以后就好搞了…… 链修改+子树查询+换根 其实静态树的换根直接树链剖分就可以搞了…… 因为其实只有一样变了:子树 如果roo ...
- 【BZOJ】【2434】【NOI2011】阿狸的打字机
AC自动机+DFS序+BIT 好题啊……orz PoPoQQQ 大爷 一道相似的题目:[BZOJ][3172][TJOI2013]单词 那道题也是在fail树上数有多少个点,只不过这题是在x的fail ...
- 【BZOJ】【2738】&【Tsinsen】【A1333】矩阵乘法
整体二分+树状数组 过了[BZOJ][2527][POI2011]Meteors以后这题就没那么难啦~ 关键是[从小到大]依次插入数字,然后整体二分每个查询的第k大是在第几次插入中被插入的……嗯大概就 ...
- 【BZOJ】【3170】【TJOI2103】松鼠聚会
切比雪夫距离+曼哈顿距离 题解:http://www.cnblogs.com/zyfzyf/p/4105456.html 其实应该先做这题再做[BZOJ][3210]花神的浇花集会的吧…… 我们发现d ...
随机推荐
- <head>中<meta name="viewport" content="width=device-width,initical-scale=1"的作用>
<meta name="viewport" content="width=device-width,initical-scale=1"的作用> co ...
- JVM Management API
JVM本身提供了一组管理的API,通过该API,我们可以获取得到JVM内部主要运行信息,包括内存各代的数据.JVM当前所有线程及其栈相关信 息等等.各种JDK自带的剖析工具,包括jps.jstack. ...
- 错误 Metadata file 'C:\Common\bin\Debug\Common.dll' could not be found
一个通用方法de类库/总是报这个错误/很明显就是没有成功生成程序集... 但是就是找不到哪里的错误!!!! 如果是代码写错的话,可能会直接提示在哪个文件中哪行代码写错了,然后dll生成不了,但是这个错 ...
- java8入门 错误:找不到或者无法加载主类
如果你也遇上的这个问题,但是如果你的Java版本不是6以上,这个解决方案可能就不适合你... 最近在跟着李兴华老湿的视频<<编程开发入门Java 8>>的学习Java... 但 ...
- Javascript的动态增加‘类’的方法
1.我们可以为每一个实例对象增加方法.也就是说我们在每次使用‘类’之外的方法时候,都需要创建一次. function Dog(){ window.alert('I am a dog!'); } va ...
- PHP用curl伪造IP和来源
以前没有这么搞过. 今天群里一个朋友在问这个问题. 查了下,CURL确实很强悍的可以伪造IP和来源. 1.php 请求 2.php . 1.php代码: $ch = curl_init(); curl ...
- 修改Linux的SSH远程连接端口 技巧
将SSH终端服务的端口由 22 修改为别的端口以防攻击黑客直接猜解您的服务器密码 首先修改配置文件 vi /etc/ssh/sshd_config 找到 #Port 22 一段,这里是标识默认使用 2 ...
- jquery.SuperSlide.js只需要调用一个插件就能实现网页大部分特效--推荐
很棒的一个插件,http://www.superslide2.com/
- 分享一个Visual Studio的背景插件,让堆码更富情趣
忘记一件重要的事情,我使用的是VS 2012版,其他更高版本应该是可以找到的,以下版本就不清楚了.有可能找不到,见谅,也不是我开发的,只是偶尔碰到,拿出来让大家知道. 上周某日,新生命群里面还是一如既 ...
- 2015-9月份,Android开发,面试题总结,主要记录没有答出来的问题
9月13日,秒针面试(跪) 1.使用HTML5写Android 与本地应用比较 9月21日,百度一面(跪)1.Android的整个启动过程,什么阶段启动了什么进程,或者服务 2.Android系统框架 ...