luogu 2152
SuperGcd
二进制算法
1. A = B, Gcd(A, B) = A;
2. A,B为偶数, Gcd(A, B) = 2 * Gcd(A / 2, B / 2);
3. A 为偶数, B 为奇数,Gcd(A, B) = Gcd(A / 2, B);
4. A,B为奇数, Gcd(A, B) = Gcd(A - B, B)
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string>
#include <cmath>
#include <cstring> using namespace std;
const int N = 2e5 + ; int C[N * ];
char s[N]; struct Node {
inline void Init(int A[]) {
scanf("%s", s); int Len = strlen(s); A[] = Len; for(int i = ; i <= Len; i ++) A[i] = s[i - ] - '';
}
inline int Cmp(int A[], int B[]) {
if(A[] > B[]) return ; if(A[] < B[]) return -;
for(int i = ; i <= A[]; i ++) if(A[i] > B[i]) return ; else if(A[i] < B[i]) return -;
return ;
}
inline void Div(int A[]) {
int tmp(), j = ;
for(int i = ; i <= A[]; i ++) {tmp += A[i]; A[i] = tmp / ; tmp %= ; tmp *= ;}
for(int i = ; i <= A[] && !A[i]; i ++, j = i); A[] = A[] - j + ;
for(int i = ; i <= A[]; i ++) A[i] = A[i + j - ];
}
inline void Minus(int A[], int B[]) {
for(int i = B[], j = A[]; i >= ; i --, j --) {
if(A[j] < B[i]) {A[j] += ; A[j - ] --;} A[j] -= B[i];
}
int j = ;
for(int i = ; i <= A[] && !A[i]; i ++, j = i); A[] = A[] - j + ;
for(int i = ; i <= A[]; i ++) A[i] = A[i + j - ];
}
int a[N], b[N];
inline void Mul(int A[], int B[]) {
memset(C, , sizeof C);
int j = ; for(int i = A[]; i >= ; i --) a[++ j] = A[i];
j = ; for(int i = B[]; i >= ; i --) b[++ j] = B[i];
for(int i = ; i <= A[]; i ++) {
int x = ;
for(int k = ; k <= B[]; k ++) {C[i + k - ] += a[i] * b[k] + x; x = C[i + k - ] / ; C[i + k - ] %= ;}
C[i + B[]] = x;
}
j = A[] + B[]; while(!C[j] && j > ) j --; A[] = ;
for(int i = j; i >= ; i --) A[++ A[]] = C[i];
}
inline void Out(int A[]) {for(int i = ; i <= A[]; i ++) printf("%d", A[i]);}
} Big_num_work; void Gcd(int A[], int B[], int &tot) {
int imp = Big_num_work.Cmp(A, B); if(imp == ) return ; if(imp < ) {Gcd(B, A, tot); return ;}
int ta(), tb(); if(A[A[]] % == ) Big_num_work.Div(A), ta = ; if(B[B[]] % == ) Big_num_work.Div(B), tb = ;
if(ta && tb) Gcd(A, B, ++ tot);
else if(!ta && !tb) {Big_num_work.Minus(A, B); Gcd(A, B, tot);}
else Gcd(A, B, tot);
} int A[N], B[N], F[N]; int main() {
Big_num_work.Init(A); Big_num_work.Init(B);
int T = ; Gcd(A, B, T);
if(T == ) Big_num_work.Out(A);
else {
int Tow[]; Tow[] = , Tow[] = ; F[] = F[] = ; for(int i = ; i <= T; i ++) Big_num_work.Mul(F, Tow);
Big_num_work.Mul(A, F); Big_num_work.Out(A);
}
return ;
}
luogu 2152的更多相关文章
- BZOJ 2152 / Luogu P2634 [国家集训队]聪聪可可 (点分治/树形DP)
题意 一棵树,给定边权,求满足两点之间的路径上权值和为3的倍数的点对数量. 分析 点分治板题,对每个重心求子树下面的到根的距离模3分别为0,1,2的点的个数就行了. O(3nlogn)O(3nlogn ...
- BZOJ 2152 & 点分治
Description: 只是打法法塔前测试一下板子 Code: /*================================= # Created time: 2016-04-20 14:3 ...
- Luogu 魔法学院杯-第二弹(萌新的第一法blog)
虽然有点久远 还是放一下吧. 传送门:https://www.luogu.org/contest/show?tid=754 第一题 沉迷游戏,伤感情 #include <queue> ...
- luogu p1268 树的重量——构造,真正考验编程能力
题目链接:http://www.luogu.org/problem/show?pid=1268#sub -------- 这道题费了我不少心思= =其实思路和标称毫无差别,但是由于不习惯ACM风格的题 ...
- BZOJ 2152: 聪聪可可 树分治
2152: 聪聪可可 Description 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一 ...
- Code[VS] 2152 滑雪题解
Code[VS] 2152 滑雪题解 题目描述 Description trs喜欢滑雪.他来到了一个滑雪场,这个滑雪场是一个矩形,为了简便,我们用r行c列的矩阵来表示每块地形.为了得到更快的速度,滑行 ...
- bzoj 2152聪聪可可
2152: 聪聪可可 Time Limit: 3 Sec Memory Limit: 259 MB Description 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰 ...
- 【BZOJ】2152: 聪聪可可(点分治)
http://www.lydsy.com/JudgeOnline/problem.php?id=2152 随便点分..... 只是我在考虑一个地方逗乐.. 当路径长度mod3=0的点数直接乘起来就好. ...
- sdutoj 2152 Balloons
http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2152 Balloons Time Limit: ...
随机推荐
- 关于#define 的宏替换的一些问题
#define PI 3.14; int main() { , s = ; s = r * r * PI; s = PI * r * r; // s = 3.14; * r * r; printf(& ...
- 使用脚本将AspNetCore发布到IIS上
首先你必须要了解的是,没有脚本的情况下,如何把AspNetCore的应用发布到IIS上. 大致分为这些步骤: 安装MS C++ 2015 x86&x64 安装正确版本的.NET Core Ru ...
- Hibernate定义
Hibernate:(Object Relational Mapping)对象关系映射 对象关系映射就是在操作数据库之前,先将数据库的表和实体类关联起来,通过实体类的对象,就可以操作数据库,开发人 ...
- MACOS 安装mysqlclient 的 Library not loaded错误
报错场景 >>> import MySQLdb Traceback (most recent call last): File "<stdin>", ...
- sql server 2012 分页/dapper/C#拼sql/免储存过程/简易
sql server 2012新特性, 支持 OFFSET/FETCH分页, 就像mysql的limit, 比之前的各种top舒服多了, 看各位大佬们的测评文章说效率也是不相上下的, 有时候写个小工 ...
- stm32 引脚映射 和 ADC
老是弄不明白ADC的输入到底在哪,看了stm32F103Ve的datasheet,将引脚和通道的映射关系贴在下面: 好了,写到这,我已经看了中文手册一上午了,可是啥都没看懂,下午接着看,写代码不重要, ...
- 昨天521表白失败,我想用Python分析一下...表白记录和聊天记录
昨天跟喜欢的妹子表白了. 失败了!.下面是表白的聊天记录: (跟妹子已经认识一段时间) 我:灭嘤嘤,我喜欢你. 妹子:你干嘛? 我:今天520,跟你表白鸭. 妹子:那....有多喜欢? 我: 有很多很 ...
- 日期时间格式化 SimpleDateFormat与DateTimeFormatter
原文:https://www.jianshu.com/p/b212afa16f1f 1.SimpleDateFormat为什么不是线程安全的? 如果我们把SimpleDateFormat定义成stat ...
- 多个ip地址匹配正则表达式
匹配规则:多个ip地址使用,号进行分割 例如:1.1.1.1,2.2.2.2var iplist =/^((25[0-5]|2[0-4]\d|((1\d{2})|([1-9]?\d)))\.){3}( ...
- 用Xcode配置完美ACMer环境
用Xcode配置完美ACMer环境 前言 作为\(ACMer\),需求大致为强大的文本编辑功能\((VIM)\),便捷的文件模版功能以及多文件编译功能.\(vscode\)虽然强大,但是与集成\( ...