题解 | #最简真分数#

最简真分数

https://www.nowcoder.com/practice/1f1db273eeb745c6ac83e91ff14d2ec9

#include <iostream>
#include<bits/stdc++.h>
using namespace std;
int GCD(int a , int b)
{
    if(b == 0)
    {
        return a ; 
    }
    return GCD(b , a %b);
}
int main() {
    int n ; 
    cin>>n ;
    vector<int> a ; 
    int tmp ; 
    while(cin>>tmp)
    {
        a.push_back(tmp) ; 
    }
    sort(a.begin() , a.end()) ; 
    int num = 0 ; 
    for(int i = 1 ; i < a.size() ; ++ i) // 先排序之后对 遍历所有的数,当前面的数小于 后面的数, 并且两个的最大公约数为1的时候就是最简真分数。 
        for(int j = 0 ; j <i ; ++ j)
        {
            if(GCD(a[i] , a[j]) == 1 )
            {
                num++ ; 
            }
        }
    cout<<num  ; 
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

12-14 11:43
黑龙江大学 Java
用微笑面对困难:确实比较烂,可以这么修改:加上大学的qs排名,然后大学简介要写一些,然后硕士大学加大加粗,科研经历第一句话都写上在复旦大学时,主要负责xxxx,简历左上角把学校logo写上,建议用复旦大学的简历模板
点赞 评论 收藏
分享
高通滤波器v:我最近投的几个,都是要不已读不回,要不不回,还有直接拒绝的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务