首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请编写函数fun,函数的功能是:将大于形参m且紧靠m的k个素数存入XX所指的数组中。例如,若输入17,5,则应输出:19,23,29,31,37。 注意:部分源程序在文件PROG1.C文件中。 请勿改动主函数main和其他函数中的任何内容,
请编写函数fun,函数的功能是:将大于形参m且紧靠m的k个素数存入XX所指的数组中。例如,若输入17,5,则应输出:19,23,29,31,37。 注意:部分源程序在文件PROG1.C文件中。 请勿改动主函数main和其他函数中的任何内容,
admin
2018-09-27
36
问题
请编写函数fun,函数的功能是:将大于形参m且紧靠m的k个素数存入XX所指的数组中。例如,若输入17,5,则应输出:19,23,29,31,37。
注意:部分源程序在文件PROG1.C文件中。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
1 #include<stdio.h>
2 void fun(int m,int k,int xx[])
3 {
4 }
5 main()
6 {
7 int m,n,zz[1000];void NONO();
8 printf(’’\nPlease enter two integers:’’);
9 scanf(’’%d%d’’,&m,&n);
10 fun(m,n,zz);
11 for(m=0;m<n,m++)
12 printf(’’%d’’,zz[m]);
13 printf("\n’’);
14 NONO();
15 }
16 void NONO()
17 {/*本函数用于打开文件,输入测试数据,调用fun函数,输出数据,关闭文件。*/
18 int m,n, zz[1000],i;
19 FILE *rf,*wf;
20 rf=fopen(’’in.dat’’,’’r"),
21 wf=fopen(’’out.dat’’,’’w’’);
22 for(i=0,i<10; i++) {
23 fscanf(rf,’’%d %d’’,&m,&n);
24 fun(m,n,zz);
25 for(m=0;m<n;m++)fprintf(wf,’’%d’’,zz[m];
26 fprintf(wf,”\n”);
27 }
28 fclose(rf);
29 fclose(wf), }
选项
答案
1 int r=0,temp,p,sign=1; 2 for(temp=m+1;temp<m*m;temp++) 3 //从temp开始循环,判断紧靠temp的整数 4 { for(p=2;p<temp;p++) 5 {if(temp%p!=0)//判断temp是否为素数 6 sign=1;//若是素数,标志设为l 7 else 8 {sign=0;//若不是素数,标志设为0 9 break; } 10 } 11 if(sign==1&&p>=temp) 12 {if(k>=0) //判断已有的素数个数是否已经满足sum个 13 {xx[r++]=temp;//将素数temp存入数组select 14 k--;//将题目中要求的素数个数减1 15 } 16 else 17 break; 18 } }
解析
(1)该程序功能是取大于整数m且紧靠m的k个素数。其中,素数是指只能被1和自身除尽的正整数(>1),所以判别n是否为素数,只要用2~n-1这些数逐个去除n,判断余数是否为0即可。只要有一次余数为0,n就不是素数,否则n为素数。
(2)从已给部分源程序的main主函数开始入手,核心函数“fun(m,n,zz);”中的参数由题目可知,zz存放素数,n为要求的素数个数。
进入fun函数,根据前面的分析:
首先,定义、初始化变量sign,作为素数的标志;定义r,初始化为存储素数数组的起始位。然后,每判断一次temp中的值是否为素数后,使temp的值增1,再次对temp中新的值进行判断其是否为素数,不断循环此过程,直到m的值等于指定的个数,即函数中的k个数。
转载请注明原文地址:https://kaotiyun.com/show/l8xp777K
本试题收录于:
二级C语言题库NCRE全国计算机二级分类
0
二级C语言
NCRE全国计算机二级
相关试题推荐
若变量a,b 已定义为int类型并赋值21和55,要求用printf函数以a=21,b=55的形式输出,请写出完整的输出语句[]。
若有说明chars1[30]="abc",s2[]="defghi";,则在使用函数strcat(s1,s2)后,结果是()。
若运行以下程序时,从键盘输入ADescriptor<CR>(<CR>表示回车),则下面程序的运行结果是()。#include<stdio.h>main(){charc;intv0=1,v1=0,v2=0;do
“商品”与“顾客”两个实体集之间的联系一般是()。
下列关键字中,不属于C语言变量存储类别的是______。
已有定义:inti,a[10],*p;,则合法的赋值语句是
下述函数统计一个字符串中的单词个数,单词是指处在空格之间的字符序列,请填空。intword(char*s){intnum=0,flag=0;while(*s){if(【】==’’)flag=0;
编制一个好的程序,首先要保证它的正确性和可靠性,还应强调良好的编程风格,在书写功能性注释时应考虑
随机试题
A.急性心房颤动B.阵发性心房颤动C.持续性心房颤动D.永久性心房颤动E.首诊心房颤动女性,45岁,患风湿性心脏病二尖瓣狭窄20年。近1个月来多次突发心悸。心电图证实为心房颤动,持续几分钟至几小时不等,可自行恢复。应诊断为
私人物品与公共物品的主要区别在于()
头面先肿,继而波及全身,小便短少,发热恶风者,多因全身水肿,肿势较缓,肢体困重,脘闷纳呆,苔白腻者,多因
提示肺动脉高压的体征提示右心功能不全的体征
材料1:V市是z省面积最大、人口最多的设区市,户籍人口超900万,同时也是“一带一路”重要节点城市、全国性综合交通枢纽和先进制造业基地之一,城市服务行业发展迅速。然而,随着商业服务模式的分工细化,越来越多的人从事与销售有关的基础服务行业,而对劳动
“不观高崖,何以知颠坠之患?不临深渊,何以知没溺之患?不观巨海,何以知风波之患?”对这一说法的理解,正确的是()。
"WewantSingaporetohavetheX-factor,thatbuzzthatyougetinLondon,Paris,orNewYork".ThatishowLeeHsienLoong,Sin
BSP过程定义以前,需要做的几件事与BSP成败密切相关,其中研究成员必须建立和理解【】及资源生命周期概念。
Aresmarterkidssmartenoughtoavoidalcoholanddrugs?Fordecades,scientistshaddocumentedthatthosewithlowerIQandle
【B1】【B3】
最新回复
(
0
)