HUST 1588 辗转数对 []【数学】

66 篇文章 0 订阅
34 篇文章 0 订阅

题目链接:https://vjudge.net/problem/HUST-1588
——————————————————————————————————–.
1588 - 辗转数对

时间限制:1秒 内存限制:128兆
139 次提交 23 次通过
题目描述
假设当前有一个数对(a, b),我们可以通过一步将这个数对变为一个新数对(a + b, b)或者是(a, a + b)。
初始的数对为(1, 1),你的任务是找到一个数字k,即通过最少的步数使得这个数对中至少一个数字等于n。
输入
输入包括多组数据,每组数据包括一行,每行有一个整数n。
输出
每组数据输出一行,每行一个整数n。
样例输入
5
3
样例输出
3
0
提示
第一个样例的方法是 (1,1)  →  (1,2)  →  (3,2)  →  (5,2),共3步。
来源
——————————————————————————————————–.
解题思路:

这个题不难发现,对于我们累加出来的(a,b)一定是互质的
然后想到Gcd(x,y)过程中的x,y就是要保证互质一直处理下去的
那么其实就是在问gcd过程中x%y要减多少次
那么接下来我们枚举终点(i,n)维护最小值即可

附本题代码
——————————————————————————————————–.

int ans;

bool gett(int a,int b){
    if(gcd(a,b)!=1) return false;
    int res = 1;
    while(a!=1||b!=1){
        if(a>b) a=a-b;
        else    b=b-a;
        res++;
    }
    ans = min(ans,res);
    return true;
}

int main(){
    int n;
    while(~scanf("%d",&n)){
        ans = INF;
        if(n==1) {puts("0");continue; }
        if(n==2) {puts("1");continue; }
        for(int i=1;i<=n;i++)       get(i,n-i);
        printf("%d\n",ans);
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值