题目描述
给出n个正整数,任取两个数分别作为分子和分母组成最简真分数,编程求共有几个这样的组合。
输入描述:
每组包含n(n<=600)和n个不同的整数,整数大于1且小于等于1000。
输出描述:
每行输出最简真分数组合的个数。
示例1
输入
7 3 5 7 9 11 13 15 3 2 4 5 0
输出
17 2
代码:
//真分数是分子小于分母的分数, 最简真分数是分子与分母没有共同公约数
//当gcd(a,b)==1时表示a,b(a>b)没有共同的公约数
#include<iostream>
#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std;
int main()
{
int n;
while(cin>>n)
{
if(!n)
break;
vector<int> s;
int a;
for(int i=0;i<n;i++)
{
cin>>a;
s.push_back(a);
}
int num=0;
for(int i=0;i<s.size()-1;i++)
for(int j=i+1;j<s.size();j++)
{
if(__gcd(s[j],s[i])==1)
num++;
}
cout<<num<<endl;
}
return 0;
}