-
题目描述:
-
给出n个正整数,任取两个数分别作为分子和分母组成最简真分数,编程求共有几个这样的组合。
-
输入:
-
输入有多组,每组包含n(n<=600)和n个不同的整数,整数大于1且小于等于1000。
当n=0时,程序结束,不需要处理这组数据。
-
输出:
-
每行输出最简真分数组合的个数。
-
样例输入:
-
7 3 5 7 9 11 13 15 3 2 4 5 0
-
样例输出:
-
17 2
该算法,性能上并不是很优越。
#include<stdio.h>
int prime[10000];
bool mark[10000];
int num[600];
int primeSize;
void init() { //素数筛法
primeSize = 0;
for (int i = 2; i <= 10000; i++) {
if (mark[i] == true)
continue;
prime[primeSize++] = i;
for (int j = i * i; j <= 10000; j += i)
mark[j] = true;
}
}
int main() {
init();
int n;
while (scanf("%d", &n) != EOF) {
if (n == 0)
break;
for (int i = 0; i < n; i++)
scanf("%d", &num[i]);
int min = 0, max = 0;
int res = 0;
for (int i = 0; i < n; i++) {
for (int j = i + 1; j < n; j++) {
bool flag = false;
if (num[i] < num[j]) {
min = num[i];
max = num[j];
} else {
min = num[j];
max = num[i];
}
if (max % min == 0)
continue;
else {
for (int i = 0; i < primeSize; i++) {
if (prime[i] > min)
break;
if (max % prime[i] == 0 && min % prime[i] == 0) {
flag = true;
break;
}
}
}
if (flag)
continue;
else
res++;
}
}
printf("%d\n", res);
}
return 0;
}
题目链接:
http://ac.jobdu.com/problem.php?pid=1465