Educational Codeforces Round 39 Editorial B(Euclid算法,连续-=与%=的效率)
You have two variables a and b. Consider the following sequence of actions performed with these variables:
- If a = 0 or b = 0, end the process. Otherwise, go to step 2;
- If a ≥ 2·b, then set the value of a to a - 2·b, and repeat step 1. Otherwise, go to step 3;
- If b ≥ 2·a, then set the value of b to b - 2·a, and repeat step 1. Otherwise, end the process.
Initially the values of a and b are positive integers, and so the process will be finite.
You have to determine the values of a and b after the process ends.
The only line of the input contains two integers n and m (1 ≤ n, m ≤ 1018). n is the initial value of variable a, and m is the initial value of variable b.
Print two integers — the values of a and b after the end of the process.
12 5
0 1
31 12
7 12
Explanations to the samples:
- a = 12, b = 5  a = 2, b = 5 a = 2, b = 5 a = 2, b = 1 a = 2, b = 1 a = 0, b = 1; a = 0, b = 1;
- a = 31, b = 12  a = 7, b = 12. a = 7, b = 12.
官方题解:
The answer can be calculated very easy by Euclid algorithm (which is described in the problem statement), but all subtractions will be replaced by taking by modulo.
题意:
Euclid算法,和题意一样,我最开始是按照题目给的流程按部就班的写,a,b的范围为10^18,要开long long,但是在text3 10^18 7就TLE了。
于是后面看到大佬的代码,以及官方题解,发现-=的话,效率会很低,改成%=即可。
代码:
#include<bits/stdc++.h>
long long a, b;
int main(){
	scanf("%lld %lld", &a, &b);
	while(a && b){
		if(a>=2*b) a%= 2*b;
		else if(b>=2*a) b%=2*a;
		else break;
	}
	printf("%lld %lld", a, b);
}Educational Codeforces Round 39 Editorial B(Euclid算法,连续-=与%=的效率)的更多相关文章
- Educational Codeforces Round 39 (Rated for Div. 2) G
		Educational Codeforces Round 39 (Rated for Div. 2) G 题意: 给一个序列\(a_i(1 <= a_i <= 10^{9}),2 < ... 
- Educational Codeforces Round 39
		Educational Codeforces Round 39 D. Timetable 令\(dp[i][j]\)表示前\(i\)天逃课了\(j\)节课的情况下,在学校的最少时间 转移就是枚举第\ ... 
- #分组背包 Educational Codeforces Round 39 (Rated for Div. 2)  D. Timetable
		2018-03-11 http://codeforces.com/contest/946/problem/D D. Timetable time limit per test 2 seconds me ... 
- Educational Codeforces Round 68 Editorial
		题目链接:http://codeforces.com/contest/1194 A.Remove a Progre ... 
- Educational Codeforces Round 39 (Rated for Div. 2) B. Weird Subtraction Process[数论/欧几里得算法]
		https://zh.wikipedia.org/wiki/%E8%BC%BE%E8%BD%89%E7%9B%B8%E9%99%A4%E6%B3%95 取模也是一样的,就当多减几次. 在欧几里得最初的 ... 
- Educational Codeforces Round 39 (Rated for Div. 2) 946E E. Largest Beautiful Number
		题: OvO http://codeforces.com/contest/946/problem/E CF 946E 解: 记读入串为 s ,答案串为 ans,记读入串长度为 len,下标从 1 开始 ... 
- Educational Codeforces Round 53 Editorial
		After I read the solution to the problem, I found that my solution was simply unsightly. Solved 4 ou ... 
- codeforces  Educational Codeforces Round 39 (Rated for Div. 2)  D
		D. Timetable time limit per test 2 seconds memory limit per test 256 megabytes input standard input ... 
- [Educational Codeforces Round 16]E. Generate a String
		[Educational Codeforces Round 16]E. Generate a String 试题描述 zscoder wants to generate an input file f ... 
随机推荐
- Django之表高级操作
			目录 一.如何开启自己的测试脚本? 二.对表数据的添加.更新.删除 1.create() 2.update() 3.delete() 4.查看执行的sql语句 三. 单表查询13个操作 返回Query ... 
- [ASP.NET Core 3框架揭秘] Options[1]: 配置选项的正确使用方式[上篇]
			依赖注入不仅是支撑整个ASP.NET Core框架的基石,也是开发ASP.NET Core应用采用的基本编程模式,所以依赖注入十分重要.依赖注入使我们可以将依赖的功能定义成服务,最终以一种松耦合的形式 ... 
- PHP 对接 饿了么开放平台 接单
			<?php # 一开始使用的是API方式对接,所以我这里是API的方式+SDK的结合 (除了获取token之外都是使用SDK方式,所以看到的朋友还是直接使用纯SDK方式对接最好),因为我这里使用 ... 
- c++数字和字符之间的转化
			关于C++中数与字符之间的转化 在c++中我们经常遇到需要把一个数变成字符,或者把字符变为一个数,c++中没有直接的转化函数,故我们需要自己去写函数去转化,这里我将介绍两种比较简单的方法: 法一: s ... 
- Django之models字段属性
			目录 常用字段 AutoField IntegerField CharField 自定义及使用char DateField DateTimeField 字段合集 字段参数 null unique db ... 
- (01)hibernate框架环境搭建及测试
			---恢复内容开始--- 1.创建javaweb项目 2.导包 hibernate包 hibernate\lib\required\*.jar 数据库驱动包 mysql-connector-java- ... 
- oracle-按年、月、周、日、时、分 分组查询统计数据,无数据补零(connect by)
			目的:统计一段时间内每年.每月.每周.每日.每时.每分数据,无数据时自动补零 思路:1. 生成给定时间段对应日期 2. 将原表中该时间段内的不为0的数据量统计出来 3. 用left join连接起来, ... 
- Spring Boot 入门(十):集成Redis哨兵模式,实现Mybatis二级缓存
			本片文章续<Spring Boot 入门(九):集成Quartz定时任务>.本文主要基于redis实现了mybatis二级缓存.较redis缓存,mybaits自带缓存存在缺点(自行谷歌) ... 
- 从头学pytorch(十七):网络中的网络NIN
			网络中的网络NIN 之前介绍的LeNet,AlexNet,VGG设计思路上的共同之处,是加宽(增加卷积层的输出的channel数量)和加深(增加卷积层的数量),再接全连接层做分类. NIN提出了一个不 ... 
- CTO说|非容器化应用怎么玩多云?Kubernetes不管我们管啊
			Kubernetes已经成为容器编排系统的事实标准,是现在主流的跨云容器化应用操作系统. 但是,Kubernetes的目标并不是容器本身,而是承载其上的应用,本质上是为了解决(容器化)应用上云这个难题 ... 
