news 2026/5/15 5:03:27

《P2152 [SDOI2009] SuperGCD》

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
《P2152 [SDOI2009] SuperGCD》

题目描述

Sheng bill 有着惊人的心算能力,甚至能用大脑计算出两个巨大的数的最大公约数!因此他经常和别人比赛计算最大公约数。有一天 Sheng bill 很嚣张地找到了你,并要求和你比赛,但是输给 Sheng bill 岂不是很丢脸!所以你决定写一个程序来教训他。

输入格式

共两行,第一行一个整数 a,第二行一个整数 b。

输出格式

一行,表示 a 和 b 的最大公约数。

输入输出样例

输入 #1复制

12 54

输出 #1复制

6

说明/提示

数据规模与约定
  • 对于 20% 的数据,有 0<a,b≤1018。
  • 对于 100% 的数据,有 0<a,b≤1010000。

代码实现:

#include <bits/stdc++.h> using namespace std; const long long MOD = 10000000000000000ll; const int MAXN = 700; long long A[MAXN], B[MAXN]; char buf[MAXN << 4]; inline long long str2ll(char s[], int l, int r) { long long res = 0, pow10 = 1; for (int i = l; i <= r; i++) res += (s[i] ^ 48) * pow10, pow10 *= 10ll; return res; } inline void read_big(long long x[]) { scanf("%s", buf + 1); int len = x[0] = strlen(buf + 1); x[0] = (len + 15) >> 4; for (int i = 1; i <= (len >> 1); i++) swap(buf[i], buf[len - i + 1]); // 修复:将i的定义移到for循环外,扩大作用域 int i; for (i = 1; i + 15 <= len; i += 16) x[(i + 15) >> 4] = str2ll(buf, i, i + 15); if (i <= len) x[x[0]] = str2ll(buf, i, len); } inline void print_big(long long x[]) { printf("%lld", x[x[0]]); for (int i = x[0] - 1; i >= 1; i--) printf("%016lld", x[i]); } inline void cp(long long a[], long long b[]) { memcpy(b, a, MAXN << 3); } inline void clr(long long x[]) { memset(x, 0, MAXN << 3); } inline bool is_even(long long x[]) { return !(x[1] & 1); } inline void div2(long long x[]) { bool rem[MAXN] = {0}; if (!x[0]) return; for (int i = x[0]; i; i--) rem[i - 1] = x[i] & 1, x[i] >>= 1; for (int i = x[0]; i; i--) if (rem[i]) x[i] += MOD >> 1; while (x[0] && !x[x[0]]) --x[0]; } inline void mul2(long long x[]) { long long carry = 0; for (int i = 1; i <= x[0] + 1; i++) { x[i] = (x[i] << 1) + carry; carry = x[i] / MOD; x[i] %= MOD; } while (x[x[0] + 1]) ++x[0]; } inline int cmp(long long a[], long long b[]) { if (a[0] > b[0]) return 1; if (a[0] < b[0]) return -1; for (int i = a[0]; i; i--) { if (a[i] > b[i]) return 1; if (b[i] > a[i]) return -1; } return 0; } inline void sub(long long a[], long long b[], long long res[]) { clr(res); for (int i = 1; i <= a[0]; i++) { res[i] += a[i] - b[i]; if (res[i] < 0) res[i] += MOD, --res[i + 1]; } res[0] = a[0]; while (res[0] && !res[res[0]]) --res[0]; } long long tmp[MAXN], res[MAXN]; inline void big_gcd(long long a[], long long b[]) { clr(res); if (cmp(a, b) == -1) cp(a, tmp), cp(b, a), cp(tmp, b); bool a_even, b_even; int cnt2 = 0; while (b[0]) { a_even = is_even(a); b_even = is_even(b); if (a_even && b_even) { cnt2++; div2(a); div2(b); } else if (!a_even && b_even) { div2(b); } else if (a_even && !b_even) { div2(a); } else { sub(a, b, tmp); cp(tmp, a); } if (cmp(a, b) == -1) cp(a, tmp), cp(b, a), cp(tmp, b); } cp(a, res); while (cnt2--) mul2(res); } int main() { read_big(A); read_big(B); big_gcd(A, B); print_big(res); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/3 15:52:11

文献检索网站有哪些:常用学术文献检索平台汇总

科研新人做综述时最痛苦&#xff1a;一搜就是几十页论文&#xff0c;重复、无关、没用。下面三款工具让我效率翻倍。 ① WisPaper&#xff08;智能学术搜索 文献管理&#xff09; 官网&#xff1a;https://www.wispaper.ai WisPaper 能通过关键词和语义搜索快速找到相关文献&…

作者头像 李华
网站建设 2026/5/10 21:54:08

uniapp+springboot基于微信小程序的个性化漫画书籍图书小说阅读推荐系统的设计与实现_cjrtkn10_论文 书签 大小章节

文章目录具体实现截图主要技术与实现手段关于我本系统开发思路java类核心代码部分展示结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;具体实现截图 同行可拿货,招校园代理 uniappSpringboot_cjrtkn0_论文 书签 大小章节 …

作者头像 李华
网站建设 2026/5/10 14:29:54

好用的物联网网关开发机构

合肥奥鲲电子科技有限公司&#xff1a;专业可靠的物联网网关开发解决方案提供商行业背景与企业定位随着工业4.0和数字化转型的深入推进&#xff0c;物联网网关作为连接物理世界与数字世界的桥梁&#xff0c;正成为智能制造和智能系统建设的核心组件。合肥奥鲲电子科技有限公司自…

作者头像 李华
网站建设 2026/5/8 10:19:03

2025 年值得选择的 TVC 视频制作服务推荐

在 2025 年&#xff0c;我们为您精心整理了年度最值得选择的 TVC 视频制作服务商榜单。这些顶级的 AI TVC 视频服务商各具特色&#xff0c;能够满足不同企业的需求。无论是品牌宣传还是产品推广&#xff0c;它们都能为您提供高质量的视频制作&#xff0c;帮助您在激烈的市场竞争…

作者头像 李华
网站建设 2026/5/13 3:19:31

青年演员李俊霆获Astria盛典“最佳演技突破演员”

12月14日&#xff0c;Astria星雅奖全球电视剧颁奖盛典在泰国曼谷举行。前段时间热播的谍战纪实传奇剧《沉默的荣耀》,与英国传记历史剧《王冠》第六季、战争剧《SAS&#xff1a;叛逆勇士》&#xff0c;共同获评最佳电视连续剧&#xff1b;英国演员加里奥德曼、莫妮卡多兰分获最…

作者头像 李华