当前位置: 首页 > news >正文

《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; }
http://www.gsyq.cn/news/109211.html

相关文章:

  • 2025年12月祛痘沐浴露推荐排行榜:十款热门产品深度评测与选购指南 - 十大品牌推荐
  • Qwen3-14B-MLX-4bit的长文本处理与YaRN扩展
  • 2025年易久伺服压装系统权威推荐:精密装配领域技术口碑与市场表现解析 - 十大品牌推荐
  • 雪深监测站:积雪厚度与降雪总量的信息采集
  • 爱玩机工具箱 S-22.1.0.1,强大的手机玩机刷机模块工具箱,免Root也能隐藏应用
  • 如何用GPT-SoVITS实现高质量语音合成?开源方案全解析
  • 易语言数据库操作:结构化数据管理的核心
  • 2025 年 12 月无尘室起重机厂家权威推荐榜:洁净空间物料搬运的精密高效解决方案精选 - 品牌企业推荐师(官方)
  • Matlab 2025b 安装教程(保姆级)(附安装包等) - Three-Stones
  • 16、PC-BSD系统软件安装与管理指南
  • electron打包后如何打开调试模式(查看控制台)
  • python乡镇卫生所医用物资进销存系统设计与实现_qn3ueh40--pycharm Vue django flask项目源码
  • Looki L1:当AI睁开“双眼”,感知物理世界的革命已然到来
  • 【触想智能】工业触摸一体机在物流智能装备领域上的应用优势
  • 人体姿态识别终极指南:从零开始掌握智能动作分析
  • SGMICRO圣邦微 SGM2011-3.0XN3/TR SOT23-3 线性稳压器(LDO)
  • Redis的数据结合及原理的详细介绍
  • 基于 区域的空间域图像融合MATLAB实现
  • 宿迁泗洪无人机培训公司
  • 旋转升序数组上的二分搜索:为何“哪边有序“成为关键决策
  • 12、用户系统设置全攻略
  • 从Git Commit到TensorRT镜像构建:全流程技术拆解
  • 2025年义乌美国双清包税国际物流服务推荐榜 - 呼呼拉呼
  • SGMICRO圣邦微 SGM2006-3.0XN5/TR SOT23-5 线性稳压器(LDO)
  • 基于Java+SpringBoot的企业进销存管理系统(源码+lw+部署文档+讲解等)
  • Directus开源数据引擎:打破传统CMS桎梏的企业级解决方案
  • Dify智能体平台调用GPT-SoVITS实现语音播报通知
  • 单片机/嵌入式修行之路 - 指南
  • 2025年LOGO设计提案能力强的公司排行,LOGO设计综合 - 工业品牌热点
  • 18、企业开源解决方案与Linux后台基础设施指南