51nod1079(中国剩余定理)
题目链接: http://www.51nod.com/onlineJudge/user.html#!userId=21687
题意: 中文题诶~
思路: 本题就是个中国剩余定理模板题,不过模拟也可以过,而且时间复杂度嘛~
我们可以知道gcd得出两个数的最大公约在最坏的情况下(a, b是相邻的两个斐波拉契数)是O(logn)的, 同理可以知道exgcd也是O(lgn)时间复杂度,因此中国剩余定理时间复杂度是O(nlogn); 而模拟的话最坏的情况下需要O(n*x)的时间~本题两种算法都是15ms...
这里给出一个关于gcd时间复杂度分析的博客: http://blog.csdn.net/zeroonet/article/details/53375313
我们先说一下模拟.首先我们知道如果x%a=m的话, x=k*a+m.
对于 x%a1=m1, 很显然x(min)=m, 如果再加一组条件 x%a2=m2, 若当前x(min)不满足条件2的话, 我们找下一个(我们可以想象满足条件1的数据升序排列)满足条件1的数据,即a1+m,再判断其是否满足条件2, 很显然我们只要地推下去就能找到同时满足条件1, 2的最小数据; 如果再加一个条件 x%a3=m3呢? 前面我们已经招到了满足条件1, 2的最小数据
x(min), 若其不满足条件3话, 我们找下一个满足条件1, 2的数据, 即x(min)+lcm(a1, a2)(此题中ai与aj互质,所以直接相乘就好啦,并且由这里我们不难看出最坏情况下即每次加2时其时间复杂度为O(x)), 再判断其是否满足条件3, 最终我们可以招到同时满足三个条件的最小数;
那么,很明显对于要满足n个这样的条件的答案我们也可以用这个方法求到啦~
代码:
#include <bits/stdc++.h>
#define MAXN 20
#define ll long long
using namespace std; int main(void){
int n;
ll p[MAXN], m[MAXN], ans=, gg=;
scanf("%d", &n);
for(int i=; i<n; i++){
scanf("%lld%lld", &m[i], &p[i]);
}
ans=p[];
for(int i=; i<n-; i++){
gg*=m[i];
while(ans%m[i+]!=p[i+]){
ans+=gg;
}
}
printf("%lld\n", ans);
return ;
}
那么中国剩余定理的模板呢~

至于证明嘛, 暂时还没想到(望路过的大神教一下)~
代码:
#include <bits/stdc++.h>
#define MAXN 20
#define ll long long
using namespace std; ll p[MAXN], m[MAXN];
int n; void exgcd(ll a, ll b, ll& x, ll& y){ //exgcd求乘法取模运算的逆元
if(!b){
y=, x=;
return;
}else{
exgcd(b, a%b, x, y);
ll temp=x;
x=y;
y=temp-a/b*y;
}
} ll crt(void){
ll M=, ans=;
for(int i=; i<n; i++){
M*=m[i];
}
for(int i=; i<n; i++){
ll mi=M/m[i], x, y;
exgcd(mi, m[i], x, y);
ans=(ans+p[i]*x*mi)%M;
}
if(ans<){
ans+=M;
}
return ans;
} int main(void){
scanf("%d", &n);
for(int i=; i<n; i++){
scanf("%lld%lld", &m[i], &p[i]);
}
printf("%lld\n", crt());
return ;
}
51nod1079(中国剩余定理)的更多相关文章
- 51nod1079 中国剩余定理【数论】
一个正整数K,给出K Mod 一些质数的结果,求符合条件的最小的K.例如,K % 2 = 1, K % 3 = 2, K % 5 = 3.符合条件的最小的K = 23. Input 第1行:1个数N表 ...
- 51nod1079 poj2891 中国剩余定理与其扩展
题目链接:http://www.51nod.com/Challenge/Problem.html#!#problemId=1079 一个正整数K,给出K Mod 一些质数的结果,求符合条件的最小的K. ...
- ACM/ICPC 之 中国剩余定理+容斥原理(HDU5768)
二进制枚举+容斥原理+中国剩余定理 #include<iostream> #include<cstring> #include<cstdio> #include&l ...
- 中国剩余定理(Chinese Remainder Theorem)
我理解的中国剩余定理的含义是:给定一个数除以一系列互素的数${p_1}, \cdots ,{p_n}$的余数,那么这个数除以这组素数之积($N = {p_1} \times \cdots \tim ...
- HDU 5446 中国剩余定理+lucas
Unknown Treasure Time Limit: 1500/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Other ...
- poj1006生理周期(中国剩余定理)
/* 中国剩余定理可以描述为: 若某数x分别被d1..….dn除得的余数为r1.r2.….rn,则可表示为下式: x=R1r1+R2r2+…+Rnrn+RD 其中R1是d2.d3.….dn的公倍数,而 ...
- poj 1006:Biorhythms(水题,经典题,中国剩余定理)
Biorhythms Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 110991 Accepted: 34541 Des ...
- UVA 11754 (暴力+中国剩余定理)
题目链接: http://www.bnuoj.com/v3/problem_show.php?pid=20172 题目大意:有C个模方程,每个方程可能有k余数,求最小的S个解. 解题思路: 看见模方程 ...
- poj1006-Biorhythms(中国剩余定理)
一,题意:右上角中文.二,思路: 1,由题意得出方程组 2,利用中国剩余定理求解 3,求出最小正整数三,步骤: 1,由题意得出方程组 (n+d) % 23 = p ; (n+d) % 28 = e ; ...
随机推荐
- 84 tune2fs-调整系统参数
tune2fs命令允许系统管理员调整"ext2/ext3"文件系统中的可该参数.Windows下面如果出现意外断电死机情况,下次开机一般都会出现系统自检.Linux系统下面也有文件 ...
- LVS持久连接
LVS持久连接 源地址HASH ipvs的连接模板 可以通过ipvsadm -L -c 持久连接持久客户端连接 PCC:在固定时间内将来自于同一个客户端发往VIP的所有请求统统定向至同一个RS0表示所 ...
- spring-初始化完成后运行指定内容
方案1:继承ApplicationListener public class InstantiationTracingBeanPostProcessor implements ApplicationL ...
- 8.Android 系统状态栏沉浸式/透明化解决方案
转载:http://www.jianshu.com/p/34a8b40b9308 前言 网上已经有很多有关于系统状态栏的解决方案,这篇文章也不会有什么新奇的解决方案,都是本人经过自己试验,统计提炼出来 ...
- Processing基础之绘画
图形 //在(x, y)绘制点 point(x, y); //(x1, y1)到(x2, y2)的一条线 line(x1, y1, x2, y2); rect(x, y, weight, height ...
- 图解JVM字节码执行引擎之栈帧结构
一.执行引擎 “虚拟机”的概念是相对于“物理机”而言的,这两种“机器”都有执行代码的能力.物理机的执行引擎是直接建立在硬件处理器.物理寄存器.指令集和操作系统层面的:而“虚拟机”的执行引擎是 ...
- Solve
/// <summary> /// Solves this instance. /// </summary> /// <returns>IFeatureClass. ...
- ajax 提交表单文件上传
<form action="" method="post" enctype="multipart/form-data" id=&quo ...
- HTML5学习笔记(持续更新中....)
平时的工作中,不知不觉我们应用了很多HTML5,但当正儿八经问起来你对HTML5了解多少,很多时候都有点懵. 做个简单的HTML5总结.包括简介.要学的知识点.凌乱的知识点 HMTL5简介 定义:ht ...
- Unity自动打包 apk
1.流程 Unity打包 apk,会把Unity安装目录下的默认 AndroidManifest.Xml 文件覆盖到apk中去,同时还会拷贝该文件所在目录下的其它默认设置文件,如 res 和 asse ...