东华OJ-基础题-120-顺序的分数(C++)

  • 问题描述
    输入一个自然数N,请写一个程序来增序输出分母小于等于N的既约真分数(即无法再进行约分的小于1的分数)
  • 输入说明
    单独的一行,一个自然数N(1...20)
  • 输出说明
    每个分数单独占一行

按照分数大小升序排列

对于分子为0的分数,仅输出0/1,不输出其它分母的分数,比如0/2, 0/3。

  • 输入范例
cpp 复制代码
4
  • 输出范例
cpp 复制代码
0/1
1/4
1/3
1/2
2/3
3/4

感想:构造真约数string 类型,把真约数装vector里,再真约数排序;输出即可。

代码如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

//比较真约数的大小,降序排序
bool compare(const string &a,const string &b) {
    auto pos_left = a.find('/');
    auto pos_right = b.find('/');
    int left_numerator = stoi(a.substr(0,pos_left));//左边真约数的分子
    int left_denominator = stoi(a.substr(pos_left+1));//左边真约数的分母
    int right_numerator = stoi(b.substr(0,pos_right));//右边真约数的分子
    int right_denominator = stoi(b.substr(pos_right+1));//右边真约数的分母

    return left_numerator*right_denominator<left_denominator*right_numerator;
}

bool commonDivisor(const string &s) {
    auto pos = s.find('/');
    int a =  stoi(s.substr(0,pos));
    int b = stoi(s.substr(pos+1));
    for(int i = 2; i<=a; ++i) {
        if(a%i==0 && b%i == 0)
            return true;
    }
    return false;
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    int n;
    cin >> n;
    vector<string> target;
    target.push_back("0/1");
    for(int i = 1; i<n; ++i) {
        for(int j = i+1; j<=n; ++j) {
            string temp = to_string(i) +"/"+to_string(j);
            if(commonDivisor(temp))
                continue;
            target.push_back(temp);
        }
    }
    sort(target.begin(),target.end(),compare);
    for(string s : target) {
        cout<<s<<endl;
    }

    return 0;
}


相关推荐
前端摸鱼匠1 天前
【AI大模型春招面试题11】什么是模型的“涌现能力”(Emergent Ability)?出现条件是什么?
人工智能·算法·ai·自然语言处理·面试·职场和发展
sqmw1 天前
MFCMouseEffect:把桌面输入反馈这件事,做成一个真正可扩展的引擎
c++·插件·引擎·鼠标特效·键鼠指示·鼠标伴宠
globaldomain1 天前
什么是用于长距离高速传输的TCP窗口扩展?
开发语言·网络·php
MORE_771 天前
leecode-合并区间-贪心算法
算法·贪心算法
沈阳信息学奥赛培训1 天前
#undef 指令 (C/C++)
c语言·开发语言·c++
2401_873204651 天前
分布式系统安全通信
开发语言·c++·算法
Dxy12393102161 天前
JS发送请求的方法详解
开发语言·javascript·ecmascript
sw1213891 天前
C++中的代理模式实战
开发语言·c++·算法
難釋懷1 天前
Lua语法入门-条件控制、函数
开发语言·junit·lua
桌面运维家1 天前
Win10打印机共享故障排查:权限与网络配置详解
开发语言·网络·php