本题要求统计给定整数M和N区间内素数的个数并对它们求和。
输入格式:
输入在一行中给出两个正整数M和N(1≤M≤N≤500)。
输出格式:
在一行中顺序输出M和N区间内素数的个数以及它们的和,数字间以空格分隔。
输入样例:
10 31
输出样例:
7 143
#pragma warning(disable:4996) //vs设置
#include<stdio.h>
#include<math.h>
int prime(int i);
int main() {
int count, m,n,i;
int sum = 0;
count = 0;
scanf("%d %d", &m, &n);
if (m == 1) //排除m为1的影响
{
m++;
}
for (i = m; i <= n; i++) {
if (prime(i) != 0) {
sum += i;
count++;
}
}
printf("%d %d", count, sum);
}
int prime(int i) //函数部分
{
int k;
for (k = 2; k <= sqrt(i); k++) //一个数平方根之后重复
{
if (i % k == 0) {
return 0;
}
}
return 1;
}
7-115 小于m的最大的10个素数与其类似。
#pragma warning(disable:4996)
#include<stdio.h>
#include<math.h>
int prime(int n);
int main() {
int i, m;
int number = 10;
scanf("%d", &m);
for (i = m-1; i > 1; i--)
{
if (prime(i) == 1&&number!=0)
{
printf("%6d", i);
number--;
}
}
return 0;
}
int prime(int i)
{
int j;
for (j = 2; j <= sqrt(i);j++)
{
if (i % j == 0)
{
return 0;
}
}
return 1;
}