传送门

非常显du然liu的一道题

就是求GCD

因为数据范围...

所以要上压位高精+非递归的辗转相减

关于辗转相减:

如果 A是二的倍数,B是二的倍数   那么GCD(A,B)=2 * GCD(A,B)

如果只有A是二的倍数   那么GCD(A,B)=GCD(A/2,B)

如果只有B是二的倍数   那么GCD(A,B)=GCD(A,B/2)

十分显然的结论...

然后不停地让大的数减去小的数

最后当它们相等时就是GCD了(因为大的减小的一直减到不能减就相当于取模)

int slove()
{
int A=read(),B=read(),i=,j=;
while(!(A&)) A>>=,i++;
while(!(B&)) B>>=,j++;
//先把A,B都除成奇数
//这样之后辗转相减时就不会出现两个数都是偶数的情况了
//可以减少判断次数
int cnt=min(i,j);
while()
{
if(A<B) swap(A,B);
if(A==B) return A<<cnt;
A=A-B;
while(!(A&)) A>>=;
}
}

普通的辗转相减法

然后就是恶心的压位高精了...

可以发现我们高精乘除都只乘除2,所以只要写高精乘2和高精除2以及高精减法就好了

重载运算符和压位都是基本操作了

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
using namespace std;
typedef long long ll;
const ll wid=;
char ch[];
struct bigint
{
ll s[],len;
bigint() { memset(s,,sizeof(s)); len=; }
inline void read()
{
scanf("%s",ch+);
int l=strlen(ch+),t=,k=; len=(l+)/;
for(int i=l;i;i--)
{
if(!(l-i)%){ k=; t++; }
s[t]+=k*(ch[i]^); k*=;
}
}
inline void print()
{
if(!len) { printf("0\n"); return; }
printf("%lld",s[len]);
for(int i=len-;i;i--) printf("%08lld",s[i]);//除了第一位不足的位用0补
printf("\n");
}
inline bool operator < (const bigint &tmp) const {
if(len!=tmp.len) return len<tmp.len;
for(int i=tmp.len;i;i--) if(s[i]!=tmp.s[i]) return s[i]<tmp.s[i];
return ;
}
inline bool operator == (const bigint &tmp) const {
return !(tmp<*this)&&!(*this<tmp);
}
inline bigint operator - (const bigint &tmp) const {
bigint u; u.len=len;
for(int i=;i<=len;i++)
{
u.s[i]+=s[i]-tmp.s[i];
if(u.s[i]<) u.s[i]+=wid,u.s[i+]--;
}
while(!u.s[u.len]&&u.len) u.len--;
return u;
}
inline bool pd(){ return s[]&; }//判断奇偶
inline void div2()//除2
{
len+=;
for(int i=len;i;i--)
{
if(s[i]&) s[i-]+=wid;
s[i]>>=;
}
while(!s[len]&&len) len--;
}
inline void mul2()//乘2
{
for(int i=;i<=len;i++) s[i]*=;
len+=;
for(int i=;i<=len;i++)
{
s[i+]+=s[i]/wid;
s[i]%=wid;
}
while(!s[len]&&len) len--;
}
}a,b; void slove()
{
int i=,j=;
while(!a.pd()) a.div2(),i++;
while(!b.pd()) b.div2(),j++;
if(i>j) i=j;
while()
{
if(a<b) swap(a,b);
if(a==b) break;
a=a-b;
while(!a.pd()) a.div2();
}
for(int k=;k<=i;k++) a.mul2();
a.print();
} int main()
{
a.read(); b.read();
slove();
return ;
}

P2152 [SDOI2009]SuperGCD的更多相关文章

  1. P2152 [SDOI2009]SuperGCD 未完成

    辗转相减求a,b的gcd其实可以优化的: 1.若a为偶数,b为奇数:gcd(a,b)=gcd(a/2,b) 2.若a为奇数,b为偶数:gcd(a,b)=gcd(a,b/2) 3.若a,b都是偶数:gc ...

  2.  P2152 [SDOI2009]SuperGCD (luogu)

    Stein算法是一种计算两个数最大公约数的算法,是针对欧几里德算法在对大整数进行运算时,需要试商导致增加运算时间的缺陷而提出的改进算法. 算法思想: 由J. Stein 1961年提出的Stein算法 ...

  3. 洛谷 P2152 [SDOI2009]SuperGCD (高精度)

    这道题直接写了我两个多小时-- 主要是写高精度的时候还存在着一些小毛病,调了很久 在输入这一块卡了很久. 然后注意这里用while的形式写,不然会炸 最后即使我已经是用的万进制了,但是交上去还是有两个 ...

  4. 洛谷 P2152 [SDOI2009]SuperGCD

    题意简述 求两个整数a,b的最大公约数0 < a , b ≤ 10 ^ 10000. 题解思路 如果 a % 2 == 0 && b % 2 == 0 gcd(a,b) = gc ...

  5. BZOJ 1876: [SDOI2009]SuperGCD

    1876: [SDOI2009]SuperGCD Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 3060  Solved: 1036[Submit][St ...

  6. bzoj 1876 [SDOI2009]SuperGCD(高精度+更相减损)

    1876: [SDOI2009]SuperGCD Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 2384  Solved: 806[Submit][Sta ...

  7. BZOJ 1876: [SDOI2009]SuperGCD( 更相减损 + 高精度 )

    更相减损,要用高精度.... --------------------------------------------------------------- #include<cstdio> ...

  8. 【BZOJ1876】[SDOI2009]SuperGCD(数论,高精度)

    [BZOJ1876][SDOI2009]SuperGCD(数论,高精度) 题面 BZOJ 洛谷 题解 那些说数论只会\(gcd\)的人呢?我现在连\(gcd\)都不会,谁来教教我啊? 显然\(gcd\ ...

  9. [BZOJ1876][SDOI2009]superGCD(高精度)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1876 分析: 以为辗转相减会TLE呢……但是好像没这个数据……就这么水过去了…… 辗转 ...

随机推荐

  1. 分享知识-快乐自己:oracle12c创建用户提示ORA-65096:公用用户名或角色无效

    今天在oracle12c上创建用户,报错了.如下图: 我很郁闷, 就打开了oracle官方网站找了下, 发现创建用户是有限制的. 2.解决方案 创建用户的时候用户名以c##或者C##开头即可. 错误写 ...

  2. Dual Path Networks(DPN)——一种结合了ResNet和DenseNet优势的新型卷积网络结构。深度残差网络通过残差旁支通路再利用特征,但残差通道不善于探索新特征。密集连接网络通过密集连接通路探索新特征,但有高冗余度。

    如何评价Dual Path Networks(DPN)? 论文链接:https://arxiv.org/pdf/1707.01629v1.pdf在ImagNet-1k数据集上,浅DPN超过了最好的Re ...

  3. 搭建自己的AppRTCDemo服务器

    http://www.jianshu.com/p/c55ecf5a3fcf http://io.diveinedu.com/2015/02/05/%E7%AC%AC%E5%85%AD%E7%AB%A0 ...

  4. VC Q&A (原创)

    Q1:External Dependencies有什么作用? A1:(网友答复:)External   Dependencies是说你没有把这个文件加入到这个工程中,但是需要这个文件的支持.当然有时是 ...

  5. Multiple webcams on ZoneMinder

    Monitoring a 3D Printer I have tidied my new workshop and I am starting to play with 3d-printing aga ...

  6. 如何卸载ubuntu软件

    你的硬盘空间已经不太足够了?如果你使用的是Ubuntu操作系统,你可能想知道如何能够卸载过时.无用的程序.有几种方法可以卸载程序,包括图形化方法和命令行方法.参考本指南,采用最适合你的方法卸载程序. ...

  7. P1880 [NOI1995]石子合并[区间dp+四边形不等式优化]

    P1880 [NOI1995]石子合并 丢个地址就跑(关于四边形不等式复杂度是n方的证明) 嗯所以这题利用决策的单调性来减少k断点的枚举次数.具体看lyd书.这部分很生疏,但是我还是选择先不管了. # ...

  8. 【Lintcode】003.Digit Counts

    题目: Count the number of k's between 0 and n. k can be 0 - 9. Example if n = 12, k = 1 in [0, 1, 2, 3 ...

  9. BZOJ3674:可持久化并查集加强版

    浅谈主席树:https://www.cnblogs.com/AKMer/p/9956734.html 题目传送门:https://www.lydsy.com/JudgeOnline/problem.p ...

  10. Scala学习——泛型[T]的6种使用(初)

    package com.dtspark.scala.basics /** * 1,scala的类和方法.函数都可以是泛型. * * 2,关于对类型边界的限定分为上边界和下边界(对类进行限制) * 上边 ...