【CF#338D】GCD Table
【题目描述】
有一张N,M<=10^12的表格,i行j列的元素是gcd(i,j)
读入一个长度不超过10^4,元素不超过10^12的序列a[1..k],问是否在某一行中出现过
【题解】
要保证gcd(x,y)=a[i],显然x=lcm(a[1],a[2]……a[k])
然后y%a[1]=0,即(y+i-1)%a[i]=0
即y%a[1]=0
y%a[2]=-1
……
y%a[n]=-(n-1)
这就转化为了中国剩余定理
求出y之后,只需验证gcd(x,y+i-1)=a[i]即可
- /*************
- CF#338D
- by chty
- 2016.11.3
- *************/
- #include<iostream>
- #include<cstdio>
- #include<cstdlib>
- #include<cstring>
- #include<ctime>
- #include<cmath>
- #include<algorithm>
- using namespace std;
- typedef long long ll;
- ll n,m1,K,A,M,ans,lcm(),m[],a[];
- inline ll read()
- {
- ll x=,f=; char ch=getchar();
- while(!isdigit(ch)) {if(ch=='-') f=-; ch=getchar();}
- while(isdigit(ch)) {x=x*+ch-''; ch=getchar();}
- return x*f;
- }
- ll gcd(ll a,ll b) {return !b?a:gcd(b,a%b);}
- void exgcd(ll a,ll b,ll &g,ll &x,ll &y)
- {
- if(b==) {x=; y=; g=a; return;}
- exgcd(b,a%b,g,x,y);
- ll t=x;x=y;y=t-a/b*y;
- }
- ll China()
- {
- for(ll i=;i<=K;i++) a[i]=-i;
- A=a[],M=m[];
- for(ll i=;i<=K;i++)
- {
- ll k,y,da=a[i]-A,g;
- exgcd(M,m[i],g,k,y);
- if(da%g) return -;
- ll t=m[i]/g;
- k*=da/g;
- k=(k%t+t)%t;
- A+=k*M;
- M=M*m[i]/g;
- A=(A+M)%M;
- }
- return A;
- }
- bool check()
- {
- if(lcm>n) return ;
- ll ans=China();
- if(ans<) return ;
- if(ans==) ans=lcm;
- if(ans+K->m1) return ;
- for(ll i=;i<=K;i++) if(gcd(lcm,ans+i-)!=m[i]) return ;
- return ;
- }
- int main()
- {
- //freopen("cin.in","r",stdin);
- //freopen("cout.out","w",stdout);
- n=read(); m1=read(); K=read();
- for(ll i=;i<=K;i++) m[i]=read();
- for(ll i=;i<=K;i++)
- {
- lcm=lcm/gcd(lcm,m[i])*m[i];
- if(lcm>n) break;
- }
- check()?puts("YES"):puts("NO");
- return ;
- }
【CF#338D】GCD Table的更多相关文章
- 【Codeforces 582A】 GCD Table
[题目链接] 点击打开链接 [算法] G中最大的数一定也是a中最大的数. G中次大的数一定也是a中次大的数. 第三.第四可能是由最大和次大的gcd产生的 那么就不难想到下面的算法: ...
- 【Codeforces 582A】GCD Table
[链接] 我是链接,点我呀:) [题意] 给你一个数组A[]经过a[i][j] = gcd(A[i],A[j])的规则生成的二维数组 让你求出原数组A [题解] 我们假设原数组是A 然后让A数组满足A ...
- 【laravel5.4】DB::table的操作
基于laravel5.4版本的查询构造器的简单几个操作:(相对于TP3.2版本) //获取指定多行多列,二维,,对象 [select] $names = ''; $names = DB::table( ...
- 【CF#303D】Rotatable Number
[题目描述] Bike是一位机智的少年,非常喜欢数学.他受到142857的启发,发明了一种叫做“循环数”的数. 如你所见,142857是一个神奇的数字,因为它的所有循环排列能由它乘以1,2,...,6 ...
- 【BZOJ 2818】 GCD
[题目链接] 点击打开链接 [算法] 线性筛出不大于N的所有素数,枚举gcd(x,y)(设为p),问题转化为求(x,y)=p的个数 设x=x'p, y=y'p,那么有(x,y)=1且 ...
- 【HDU 5382】 GCD?LCM! (数论、积性函数)
GCD?LCM! Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total ...
- 【CF 585E】 E. Present for Vitalik the Philatelist
E. Present for Vitalik the Philatelist time limit per test 5 seconds memory limit per test 256 megab ...
- 【CF 463F】Escape Through Leaf
题意 给你一棵 \(n\) 个点的树,每个节点有两个权值 \(a_i,b_i\). 从一个点 \(u\) 可以跳到以其为根的子树内的任意一点 \(v\)(不能跳到 \(u\) 自己),代价是 \(a_ ...
- 【CF 453A】 A. Little Pony and Expected Maximum(期望、快速幂)
A. Little Pony and Expected Maximum time limit per test 1 second memory limit per test 256 megabytes ...
随机推荐
- SBT构建工具
SBT Simple Build Tool. A interactive build tool. install windows可直接到http://www.scala-sbt.org/0.13/do ...
- TCP服务器端口数,最大连接数以及MaxUserPort的关系辨真
原文连接:http://www.jianshu.com/p/4a58761d758f 关于TCP服务器最大并发连接数有一种误解就是"因为端口号上限为65535,所以TCP服务器理论上的可承载 ...
- [置顶]
个人博客上线!欢迎来访~ http://onlyloveyd.cn/
简介 Hexo + Github + 个人域名 构建静态博客系统. 构建方法 参考 https://yq.aliyun.com/articles/64953 个人博客网站 Cherish Androi ...
- Django 之Ajax
必备知识:json 什么是json 定义 JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式. 它基于 ECMAScript (w3c制定的 ...
- (十一)java循环结构
while(循环的条件) {循环的语句} int a = 1; while(a < 5) { System.out.println(a);//1,2,3,4 a++; } System.out. ...
- 【ACM非算法部分】scanf()函数
scanf函数 格式说明符: %c 字符型 %d 十进制数 %i 读入十进制,八进制,十六进制数.输入的时候正常是十进制数,若输入0前缀的数将读入八进制,0x前缀读入16进制.若输 ...
- 转发一篇关于django模型详解的一篇好的博客
http://blog.csdn.net/pipisorry/article/details/45725953
- Flyway客户端使用
一.flyway介绍 Flyway是一款开源的数据库版本管理工具,它更倾向于规约优于配置的方式.Flyway可以独立于应用实现管理并跟踪数据库变更,支持数据库版本自动升级,并且有一套默认的规约,不需要 ...
- 利用脚本启动java程序
今天在工作中,需要写一个shell脚本,启动一个socket程序,从而模拟短信网关.查了一些资料,终于搞定了,现在记录一下,方便大家查阅. 为了说明使用方法,我们就用最简单的程序来实现,比如我们要运行 ...
- delphi 2010安装unidac
UniDAC是一个功能强大的非可视化跨数据库的数据访问组件,可用于Delphi,Delphi for .NET,C++Builder,and Lazarus (Free Pascal).它提供了对流行 ...