本题要求统计给定整数M和N区间内素数的个数并对它们求和。
输入格式:
输入在一行中给出两个正整数M和N(1≤M≤N≤500)。
输出格式:
在一行中顺序输出M和N区间内素数的个数以及它们的和,数字间以空格分隔。
输入样例:
10 31
输出样例:
7 143
函数版
#include<stdio.h>
#include<math.h>
int prime(int);
int main() {
int t = 0, i, k, j;
int m, n, sum = 0;
scanf("%d %d", &m, &n);
if (m == 1)
m++;
for (i = m; i <= n; i++) {
k = prime(i);
if (k != 0) {
sum += k;
t++;
}
}
printf("%d %d", t, sum);
}
int prime(int a) {
int i, t;
t = 1;
for (i = 2; i <= sqrt(a); i++) {
if (a % i == 0) {
t = 0;
break;
}
}
if (t == 0)
return 0;
else
return a;
}
普通版
#include<stdio.h>
#include<math.h>
int main() {
int i, t = 0, k, j;
int m, n, sum = 0;
scanf("%d %d", &m, &n);
if (m == 1)
m++;
for (i = m; i <= n; i++) {
k = 0;
for (j = 2; j <=sqrt(i); j++) {
if (i % j == 0) {
k = 1;
break;
}
}
if (k == 0) {//这个要写到第二个for的外面
sum += i;
t++;
}
}
printf("%d %d", t, sum);
}