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

第十三届蓝桥杯省赛JavaA组 D 题、Java C 组 G 题、Python C 组 G题——GCD(AC)

1.GCD

1.题目描述

给定两个不同的正整数 a , b a,b a,b 求一个正整数
k k k 使得 g c d ( a + k , b + k ) gcd(a+k,b+k) gcd(a+k,b+k) 尽可能 大,其中 g c d ( a , b ) gcd(a,b) gcd(a,b) 表示
a a a b b b 的最大公约数,如果存在多个 k k k, 请输出所有满 足条件的
k k k 中最小的那个。

2.输入格式

输入一行包含两个正整数 a , b a,b a,b, 用一个空格分隔。

3.输出格式

输出一行包含一个正整数 k k k

4.样例输入

5 7

5.样例输出

1

6.数据范围

1 ≤ a < b ≤ 1 0 18 1≤a<b≤10^{18} 1a<b1018

7.原题链接

GCD

2.解题思路

熟悉gcd的性质的话,根据更相减损术可以知道一个等式:
g c d ( a , b ) = g c d ( a , b − a ) gcd(a,b)=gcd(a,b-a) gcd(a,b)=gcd(a,ba)
当然这里前提是 b > = a b>=a b>=a,同样根据该式我们可以将题目给定的原式进行变形:
g c d ( a + k , b + k ) = g c d ( a + k , b − a ) gcd(a+k,b+k)=gcd(a+k,b-a) gcd(a+k,b+k)=gcd(a+k,ba)
因为 a , b a,b a,b 都是已知的,我们令 c = b − a c=b-a c=ba,当然此时需要保证b>=a,那么我们求的式子就变为了 g c d ( a + k , c ) gcd(a+k,c) gcd(a+k,c),显然这个式子的最大gcd一定为 c c c,我们只需要计算出 a a a 最少需要增加多少可以成为 c c c 的倍数,这个增量即是答案 k k k
时间复杂度: O ( 1 ) O(1) O(1)

3.Ac_code

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
typedef unsigned long long uLL;
typedef pair<int, int> PII;
#define pb(s) push_back(s);
#define SZ(s) ((int)s.size());
#define ms(s,x) memset(s, x, sizeof(s))
#define all(s) s.begin(),s.end()
const int inf = 0x3f3f3f3f;
const int mod = 1000000007;
const int N = 200010;

LL a, b;
void solve()
{
	cin >> a >> b;
	if (a > b) swap(a, b);
	LL c = b - a;
	LL g = a / c;
	if (a % c) g++;
	cout << (g * c - a) << '\n';
}
int main()
{
	ios_base :: sync_with_stdio(false);
	cin.tie(0); cout.tie(0);
	int t = 1;
	while (t--)
	{
		solve();
	}
	return 0;
}

相关文章:

  • 字节青训前端笔记 | 响应式系统与 React
  • Allegro如何输出第三方网表操作指导
  • 89. 注意力机制以及代码实现Nadaraya-Waston 核回归
  • 云原生技能树-docker caontainer 操作
  • 使用 Burpsuite 测试的常用操作(一)
  • 应届生身份为什么重要?
  • PHP MySQL Delete
  • JVM类的结构与字节码
  • 【Java IO流】字符流详解
  • 线段树入门
  • 【C语言从0到1之文件操作】(原理 画图 举例 不信教不会你 不要放收藏夹落灰 学起来好嘛)
  • java的数据类型:引用数据类型(String、数组、枚举)
  • linux系统管理
  • 2023牛客寒假算法基础集训营2(11/12)
  • linux搭建webapp实战
  • Golang语法快速上手3
  • 【JavaEE初阶】第五节.多线程 ( 基础篇 ) 线程安全问题(上篇)
  • Java技能树-操作符(二)-练习篇
  • 化繁为简、性能提升 -- 在WPF程序中,使用Freetype库心得
  • 用通知-等待机制优化锁等待问题
  • https://app.hackthebox.com/machines/Inject
  • Spring —— Spring简单的读取和存储对象 Ⅱ
  • 渗透测试之冰蝎实战
  • Mybatis、TKMybatis对比
  • Microsoft Office 2019(2022年10月批量许可版)图文教程
  • 《谷粒商城基础篇》分布式基础环境搭建
  • 哈希表题目:砖墙
  • Vue 3.0 选项 生命周期钩子
  • 【车载嵌入式开发】AutoSar架构入门介绍篇
  • 【计算机视觉 | 目标检测】DETR风格的目标检测框架解读