东华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;
}


相关推荐
程序大视界11 分钟前
【Python系列课程】Python正则表达式(下):环视、命名分组与日志实战
开发语言·python·正则表达式
xwz小王子19 分钟前
手术机器人登上Science Robotics:2毫米纤细手臂,从3厘米切口完成腰椎神经减压
算法·机器人
枫叶v.42 分钟前
Agent 分层存储架构设计:从记忆方法到中间件选型
开发语言·python
黎阳之光1 小时前
视频孪生智护供水生命线:黎阳之光赋能医疗与园区水务高质量升级
运维·物联网·算法·安全·数字孪生
Black蜡笔小新2 小时前
自动化AI算法训练服务器DLTM制造业AI质检工作站助力制造业实现AI智检
人工智能·算法·自动化
嵌入式小能手2 小时前
飞凌嵌入式ElfBoard-进程间的通信之命名管道
linux·服务器·算法
sleven fung2 小时前
MinerU与BabelDOC与KTransformers与OpenAI API库
开发语言·python·ai·langchain
萤萤七悬2 小时前
【Python笔记】AI帮实现CLI工具-使用argparse.ArgumentParser接收命令参数
开发语言·笔记·python
啦哈拉哈2 小时前
Leetcode题解记录-hot100(81-100)
算法·leetcode·职场和发展
iCxhust2 小时前
C# 命令行指令 查看二进制文件
开发语言·单片机·嵌入式硬件·c#·proteus·微机原理·8088单板机