题目描述
给出n个正整数,任取两个数分别作为分子和分母组成最简真分数,编程求共有几个这样的组合。
输入描述:
每组包含n(n<=600)和n个不同的整数,整数大于1且小于等于1000。
输出描述:
每行输出最简真分数组合的个数。
示例1
输入
7 3 5 7 9 11 13 15 3 2 4 5 0
输出
17 2
//方法一
#include<iostream>
#include<algorithm>
using namespace std;
int num(int a,int b)
{
if(b==0) return a;
else
return num(b,a%b);
}
int main()
{
int n,i,j,sum;
while(cin>>n&&n)
{
int a[n];
for(i=0;i<n;i++) cin>>a[i];
sum=0;
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;j++)
{
if(num(a[i],a[j])==1)
sum++;
}
}
cout<<sum<<endl;
}
return 0;
}
//方法二
#include<iostream>
#include<algorithm>
using namespace std;
int num(int a,int b)
{
if(b==0) return a;
else
return num(b,a%b);
}
int main()
{
int n,i,j,sum;
while(cin>>n&&n)
{
int a[n];
for(i=0;i<n;i++) cin>>a[i];
sort(a,a+n);
sum=n*(n-1);
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;j++)
{
if((a[j]%a[i])==0)
sum-=2;
else if(num(a[j],a[i])!=1)
sum-=2;
else
sum-=1;
}
}
cout<<sum<<endl;
}
return 0;
}