poj3696 欧拉函数引用
不知道错在哪里,永远T
/*
引理:a,n互质,则满足a^x=1(mod n)的最小正整数x0是φ(n)的约数
思路:求出d=gcd(L,8)
求出φ(9L/d)的约数集合,再枚举约数x,是否满足10^x = 1 (mod 9L/d)
*/
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
#define ll long long ll l,d,phi,m,factor[];
ll v[],prime[],mm;
void init(ll n){
memset(v,,sizeof v);
memset(prime, ,sizeof prime);
mm=;
for(int i=;i<=n;i++){
if(v[i]==){
v[i]=i;
prime[++mm]=i;
}
for(int j=;j<=m;j++){
if(prime[j]>v[i] || prime[j]*i>n) break;
v[i*prime[j]]=prime[j];
}
}
} ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
ll f(ll n){
ll res=n;//和1互质
for(int i=;i<=mm;i++){
if(prime[i]>n) break;
if(n%prime[i]==) res=res/prime[i]*(prime[i]-);
while(n%prime[i]==)
n/=prime[i];
}
if(n>) res=res/n*(n-);
return res;
}
ll mul(ll a,ll b,ll m)
{
ll res=;
while(b)
{
if(b&) res+=a;
if(res>m) res-=m;
a+=a;
if(a>m)
a-=m;
b>>=;
}
return res;
}
ll pow(ll a,ll b,ll m)
{
ll res=;
while(b)
{
if(b&) res=mul(res,a,m);
a=mul(a,a,m);
b>>=;
}
return res;
} int main(){
int tt=;
init(sqrt());
while(scanf("%lld",&l),l){
d=gcd(l,);
phi=f(*l/d);
if(gcd(,*l/d)!=) {
printf("Case %d: 0\n",++tt);
continue;
}
m=;
for(int i=;i*i<=phi;i++)
if(phi%i==){
factor[++m]=i;
if(i!=phi/i) factor[++m]=phi/i;
} //从小到大枚举每个约数
ll mod=*l/d,flag=;
sort(factor+,factor++m);
for(int i=;i<=m;i++){
if(pow(,factor[i],mod)%mod==){
flag=;
printf("Case %d: %lld\n",++tt,factor[i]);
break;
}
}
if(flag==) printf("Case %d: 0\n",++tt);
}
return ;
}
poj3696 欧拉函数引用的更多相关文章
- poj3696       快速幂的优化+欧拉函数+gcd的优化+互质
		
这题满满的黑科技orz 题意:给出L,要求求出最小的全部由8组成的数(eg: 8,88,888,8888,88888,.......),且这个数是L的倍数 sol:全部由8组成的数可以这样表示:((1 ...
 - 「POJ3696」The Luckiest number【数论,欧拉函数】
		
# 题解 一道数论欧拉函数和欧拉定理的入门好题. 虽然我提交的时候POJ炸掉了,但是在hdu里面A掉了,应该是一样的吧. 首先我们需要求的这个数一定可以表示成\(\frac{(10^x-1)}{9}\ ...
 - 【poj2478-Farey Sequence】递推求欧拉函数-欧拉函数的几个性质和推论
		
http://poj.org/problem?id=2478 题意:给定一个数x,求<=x的数的欧拉函数值的和.(x<=10^6) 题解:数据范围比较大,像poj1248一样的做法是不可行 ...
 - 51nod1040 最大公约数之和,欧拉函数或积性函数
		
1040 最大公约数之和 给出一个n,求1-n这n个数,同n的最大公约数的和.比如:n = 6时,1,2,3,4,5,6 同6的最大公约数分别为1,2,3,2,1,6,加在一起 = 15 看起来很简单 ...
 - HYSBZ - 3813 奇数国 欧拉函数+树状数组(线段树)
		
HYSBZ - 3813奇数国 中文题,巨苟题,巨无敌苟!!首先是关于不相冲数,也就是互质数的处理,欧拉函数是可以求出互质数,但是这里的product非常大,最小都2100000,这是不可能实现的.所 ...
 - 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 ...
 
随机推荐
- prototype和__proto__区别
			
prototype和__proto__分别是显式原型和隐式原型,直接上代码吧: function person(){ this.age = 12; } person.prototype; //Obje ...
 - 数据结构(六)查找---平衡二叉树(ASL)
			
前提 我们之前的二叉排序树的插入(构建)是按照我们输入的数据来进行的,若是我们的数据分布不同,那么就会构造不同的二叉树 { , , , , , , , , , } { , , , , , , , , ...
 - centos7环境下安装mysql5.6-----解压安装包的方法
			
参考连接:https://blog.csdn.net/qq_17776287/article/details/53536761 linux下有很多服务,如何查看服务是否启动,以mysql为例子 使用命 ...
 - mysql学习笔记--- 字符串函数、日期时间函数
			
一.常见字符串函数: 1.CHAR_LENGTH 获取长度(字符为单位) 2.FORMAT 格式化 3.INSERT 替换的方式插入 4.INSTR 获取位置 5.LEFT/RIGHT 取左 ...
 - Jupyter 魔术命令(magic commands)
			
自动重新加载更改的模块 命令参数如下所示: %autoreload: 自动重载%aimport排除的模块之外的所有模块. %autoreload 0: 禁用自动重载 %autoreload 1: 自动 ...
 - 虚拟机下Linux(终端)配置网络的方法
			
这几天在虚拟机vmware上部署centos系统,想通过内部联网用yum命令安装必需的软件,但是一直不能静态地址联网,今天终于找到一个方法centos内部设置IP,对外联网.设置过程如下: .首先是网 ...
 - Python探测主机端口是否存活
			
#!/usr/bin/python3 import socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) result = s ...
 - Git之创建仓库并上传/更新项目版本
			
1.Git配置 使用Git的第一件事就是设置你的名字和email,这些就是你在提交commit时的签名,每次提交记录里都会包含这些信息.使用git config命令进行配置: $ git config ...
 - Android关于RAM、ROM、SD卡以及各种内存的区别
			
RAM:运行时内存.相当于PC机的内存存储,用于存储应用运行时的各种对象和变量常量等,主要作用在于提高运行速度.是唯一一种断电后数据会清除的存储器. 机身内存:相当于PC机硬盘.主要包括三块区域:RO ...
 - IDEA常用快捷键和常用插件集成,持续更新......
			
用习惯了eclipse,不容易转过来,记一下! 快捷键 psvm: main 方法快捷键 sout :syso快捷键 CTRL+O: 重写父类方法 Ctrl+Alt+V :自动补全返回值 Ctrl+S ...