扩展欧几里得
小天位
这个作者很懒,什么都没留下…
展开
-
poj 2115 C Looooops(扩展欧几里德算法)
题意: 对于for(i=A ; i!=B ;i+=C)循环语句,问在k位存储系统中循环几次才会结束。 比如:当k=4时,存储的数 i 在0-15之间循环。(本题默认为无符号) 若在有限次内结束,则输出循环次数。 否则输出死循环。 二,思路: 本题利用扩展欧几里德算法求线性同余方程,设循环次数为 x ,则解方程 (A + C*x) % 2^k = B ;求原创 2017-11-16 21:11:09 · 241 阅读 · 0 评论 -
poj1061
escription 两只青蛙在网上相识了,它们聊得很开心,于是觉得很有必要见一面。它们很高兴地发现它们住在同一条纬度线上,于是它们约定各自朝西跳,直到碰面为止。可是它们出发之前忘记了一件很重要的事情,既没有问清楚对方的特征,也没有约定见面的具体位置。不过青蛙们都是很乐观的,它们觉得只要一直朝着某个方向跳下去,总能碰到对方的。但是除非这两只青蛙在同一时间跳到同一点上,不然是永远都不可能碰面的原创 2017-11-18 14:53:18 · 315 阅读 · 0 评论 -
欧几里得算法&&扩展欧几里得算法
欧几里德算法 欧几里德算法又称辗转相除法,用于计算两个整数a,b的最大公约数。 基本算法:设a=qb+r,其中a,b,q,r都是整数,则gcd(a,b)=gcd(b,r),即gcd(a,b)=gcd(b,a%b)。 第一种证明: a可以表示成a = kb + r,则r = a mod b 假设d是a,b的一个公约数,则有 d|a, d|b,而r原创 2017-09-20 21:07:57 · 312 阅读 · 0 评论 -
hdu 1576
n=A%9973 A/B%9973=x A/B=x+9973k A=Bx+9973Bk 则 n=Bx%9973 gcd(B,9973) = 1 Bx=n+9973y Bx+(-9973y)=n(不定方程) Bx≡n(mod 9973)(同余式) #include #define mod 9973 using namespace std; int ex_gcd(int a,int b原创 2017-11-30 20:45:59 · 190 阅读 · 0 评论 -
POJ-1006 Biorhythms (生物节律)
POJ1006 Biorhythms Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 139159 Accepted: 44664 Description Some people believe that there are three cycles in a perso...原创 2017-09-19 20:32:02 · 982 阅读 · 2 评论 -
poj 2891
转载: /**********************一般模线性方程组***********************/ 同样是求这个东西。。 X mod m1=r1 X mod m2=r2 ... ... ... X mod mn=rn 首先,我们看两个式子的情况 X mod m1=r1……………………………………………………………(1) X mod m2=r2…原创 2017-12-02 14:22:28 · 190 阅读 · 0 评论 -
poj1061-青蛙的约会
题意:两只蛤蟆分别在操场的x,y处,他们分别以m,n的速度向同一个方向跳,问最终他们是否可以相遇 0.设出同余方程 1.exgcd解决 //#include <bits/stdc++.h> #include <iostream> #define X 10005 #define inF 0x3f3f3f3f #define PI 3.1415...原创 2018-10-30 11:22:55 · 240 阅读 · 0 评论