问题 多项选择题

fclose(wf);

答案

参考答案:void num(int m, int k,int xx[])
{
int data=m+A; /*从大于整数m的数开始找*/
int half, I,n=0;
while(A)
{
half=data/B;
for(I=B;I<=half;I++) /*如果该数依次除以从B到一半的整数,余数都不是0,则该数是素数*/
if(data%I==O) break; /*如果余数为0,则退出循环,取下一个数判断*/
if (I>half) ’
{
xx[n]=data; n++; /*判断该数为素数后,将该数存入数组xx中,并累计素数的个数*/
}
if (n>=k) break; /*如果累计素数的个数超过了要求的个数,则退出循环*/
data++; /*如果累计素数的个数小于要求的个数,则继续取下一个数*/
}
}

解析: 本题考查的知识点如下:
(1) 循环结构与选择结构的嵌套使用。
(2) 强行退出循环结构。
(3) 特殊运算符“%”的使用。
素数是除了1和它本身之外不能被其他数整除的数(1除外)。在本题中,首先要结合相关数学知识找出判定一个数是否为素数的方法,从而对数据进行筛选。如果数据a依次除以从2到a/2的整数,余数都不是0,则该数是素数.因为所给的数据是连续的数,而且最终所求的数据的个数一定,所以这里可以使用循环结构对数据依次筛选。同时嵌套选择结构对筛选的数据进行不同的处理。在a依次除以从2到a/2的整数的过程中,只要有一次余数为0,则可退出这一层循环,即退出整除取余的循环,进入下一个数的判断中。

选择题
多项选择题