题解 | #将真分数分解为埃及分数#

将真分数分解为埃及分数

https://www.nowcoder.com/practice/e0480b2c6aa24bfba0935ffcca3ccb7b

#include <iostream>
using namespace std;

int gcd(int a, int b) {
    if (b == 0) return a;
    else return gcd(b, a % b);
}

int main() {
    string str;
    while (cin >> str) {
        int pos = str.find('/');
        long long a = stoi(str.substr(0, pos));
        long long b = stoi(str.substr(pos + 1));
        int g = gcd(a, b);
        if (g != 1) {
            a /= g;
            b /= g;
        }
        // a,b互质
        long long c;
        string ans;
        while (a > 1 && b % a != 0) {
            c = b / a + 1;
            ans += "1/" + to_string(c) + '+';
            a = a - b % a;
            b = b * c;
        }
        if (a > 1 && b % a == 0) {
            ans += "1/" + to_string(b / a);
        } else if (a == 1) {
            ans += "1/" + to_string(b);
        }
        cout << ans << endl;
    }
    return 0;
}

全部评论
最无语了这题
点赞 回复 分享
发布于 2024-03-23 21:53 江西

相关推荐

02-05 08:49
已编辑
武汉大学 Web前端
野猪不是猪🐗:36k和36k之间亦有差距,ms的36k和pdd的36k不是一个概念
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务