试题1下列程序的功能是:找出所有100以内(含100)满足i,i+4,i+10都是素数的整数i(i+10也在100以内)
试题1
下列程序的功能是:找出所有100以内(含100)满足i,i+4,i+10都是素数的整数i(i+10也在100以内)的个数cnt以及这些i之和sum。请编写函数countvalue()实现程序要求,最后调用函数writeDat()把结果cnt和sum输出到文件out.dat中。
注意:部分源程序已给出。
请勿改动主函数main()和函数writeDAT()的内容。
试题程序:
#include <stdio.h>
int cnt, sum;
int isPrime(int number)
{
int i, tag = 1;
for (i=2; tag && i<=number/2; i++)
if (number%i == 0)
tag = 0;
return tag;
}
void countValue()
{
}
void writeDat()
{
FILE *fp;
fp = fopen("out.dat", "w");
fprintf(fp, "%d\n%d\n", cnt, sum);
fclose(fp);
}
void main()
{
cnt = sum = 0;
countValue();
printf("满足条件的整数的个数=%d\n", cnt);
printf("满足条件的整数的和值=%d\n", sum);
writeDat();
试题1答案:
void countvalue()
{
int i;
for(i=2;i<=90;i++)
if(isPrime(i) && isPrime(i+4) && isPrime(i+10))
{
cnt++;
sum+=i;
}
} }
试题1分析:
该程序属于按条件查找数字的题目,考核的知识点为:(1)素数的判定;(2)统计个数并求和。
本题的解题思路是:题目要求的筛选范围是“所有100以内(含100)满足i、i+4、i+10都是素数的整数i(i+10也在100以内)”,由于最小的素数是2,且i+10要在100以内(含100),所以筛选的范围是2~90。
题目要求的筛选条件是“满足i、i+4、i+10都是素数的整数i”。在答题之前,应先通读题目已给出的源程序,在我们要实现的函数countvalue()之前给出一个在题目中从未提及的函数isPrime()。仔细分析这个函数的代码不难发现,它实现了从2~number/2内寻找能整除number的数,如果找到就使变量tag为0,此时循环条件将不成了,最终返回0,如果找不到,变量tag为1,返回1.这段代码实现的是判断一个数是够是素数。所以在函数中对筛选条件可以简化为if(isPrime(i) && isPrime(i+4) && isPrime(i+10))。
程序的流程是:调用countvalue()函数对数据进行处理,最后由writeDAT()函数将结果写入文件out.dat中。
在countvalue()函数中,For循环的功能是判断i、i+4、i+10是否都为素数,若在素数则将i累加到sum中,同时个数cnt加1,函数结束。
下列小动物要吃水果了,但是他们只能吃与自己的的单词部分发音相同的食物.苹果:milk,little 英语 2020-04-06 …
在一个有受控电流源电路中求电流的问题为什么I=0,5U1+0.5U我想的是I=0,5U1+U/2. 物理 2020-04-27 …
和英语单词me同类的是i还是you 英语 2020-05-02 …
灰太狼每次飞走的最后一句话,英语怎么说?难道说“I will be back”难道翻译成英语灰太狼 其他 2020-05-16 …
There are four people in my family.They are my fa 英语 2020-05-16 …
I think it's a wonderful place to live( ).我们英语书上用 英语 2020-05-17 …
Evangeline这个名字中的i发什么音,金山中写的是/i:/但发音听起来像/ai/ 英语 2020-05-17 …
英文IChing谁能告诉我为什么我的一本书里把英文I-Ching解释为《易经》?我查了词典《易经》 其他 2020-05-20 …
分解一个英语句子I'dlikeacupoftea.我想喝杯茶这是新概念英语中的句子,请问的是I'd 英语 2020-05-22 …
当前目录是用户当前工作的目录,下列关于当前目录的叙述中正确的是I.在当前目录下,可以采用相对路 计算机类考试 2020-05-23 …