HUST 1588 辗转数对
时间:2022-05-07
本文章向大家介绍HUST 1588 辗转数对,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
1588 - 辗转数对
时间限制:1秒 内存限制:128兆
155 次提交 27 次通过
题目描述假设当前有一个数对(a, b),我们可以通过一步将这个数对变为一个新数对(a + b, b)或者是(a, a + b)。
初始的数对为(1, 1),你的任务是找到一个数字k,即通过最少的步数使得这个数对中至少一个数字等于n。
输入输入包括多组数据,每组数据包括一行,每行有一个整数n。
输出每组数据输出一行,每行一个整数n。
样例输入
5
3
样例输出
3
2
提示第一个样例的方法是 (1,1) → (1,2) → (3,2) → (5,2),共3步。题目链接:http://acm.hust.edu.cn/problem/show/1588分析:官网给出的输出数据又是错的!正解应该如下所示,此题一直没想出怎么解,涉及到互质的问题,对于任意步骤得到的(a,b),其中a和b肯定是互质的(gcd==1)。然后想到gcd(x,y)过程中的x,y就是要保证互质一直处理下去的,那么我们此时可以O(n)枚举答案:(i,n)(当然要保证gcd(i,n)==1);再然后模拟一波减法操作。过程维护本次减法操作的总数,过程维护最小值即可。
1 #include <bits/stdc++.h>
2 using namespace std;
3 int gcd(int x,int y)
4 {
5 if(y==0)return x;
6 else return gcd(y,x%y);
7 }
8 int solve(int x,int y)
9 {
10 if(x==1)return y-1;
11 if(y==1) return x-1;
12 return (x-x%y)/y+solve(y,x%y);
13 }
14 int main()
15 {
16 int n,i,output;
17 while(cin>>n)
18 {
19 output=0x3f3f3f3f;
20 for(i=1;i<=n;i++)
21 {
22 if(gcd(i,n)==1)
23 output=min(solve(i,n),output);
24 }
25 cout<<output<<endl;
26 }
27 return 0;
28 }
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- LeetCode44|在每个树行中找最大值
- LeetCode43|最大层内元素和
- 搭建简易的物联网服务端和客户端-Maibu控制(二十一)
- LeetCode42|层数最深叶子节点的和
- LeetCode41|数组中数组出现的次数
- Django后台管理界面修改(源文件修改)
- 前端工程师不可不知的Nginx知识
- Django1.11 简单登录注册
- 基因表达聚类分析之初探SOM - 自组织特征图
- JMH - Java 代码性能测试的终极利器、必须掌握
- 从零搭建Spring Boot脚手架(6):整合Redis作为缓存
- 换一种姿势挖掘CORS漏洞
- 新的Spring OAuth2.0 授权服务器项目正式发布
- spring boot整合apollo
- 枚举和List的几个共有方法