首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请编写函数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
27
问题
请编写函数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的形式输出,请写出完整的输出语句[]。
以下程序的输出结果是【】。 #define MCRA(m) 2*m #define MCRB(n,m) 2*MCRA(n)+m main( ) { inti=2,j=3; printf("%d\n",MCRB(j,MCRA(i)
若有如下程序:main(){intx=4,y=3,x=2,t;t=x<y<z;printf("%d\n",t);}则程序运行后的输出结果是【】。
以下程序运行后的输出结果是()。main(){inta=3,b=4,c=5,t=99;if(b<a&&a<C)t=a;a=c;c=t;if(a<c&&b<C)t=b;b=a;a=t;printf(
若运行以下程序时,从键盘输入ADescriptor<CR>(<CR>表示回车),则下面程序的运行结果是()。#include<stdio.h>main(){charc;intv0=1,v1=0,v2=0;do
以下关于函数的叙述中正确的是______。
已知字母A的ASCII码为65。以下程序运行后的输出结果是【】。main(){chara,b;a=’A’+’5’-’3’;b=a+’6’-’2’;printf("%d%c\n",a,B);}
若各选项中所用变量已正确定义,fun()函数中通过return语句返回一个函数值,下列选项中错误的程序是()。
本程序用冒泡法对数组a[]的元素从大到小排序,请在程序空白处填空。voidbubble(inta[],intn){intid,max,temp;max=n-1;do{j=0;f
随机试题
胸骨右缘第2肋间触及收缩期震颤常提示
最佳的治疗方案是如果选择桩核和金瓷冠修复,对此牙牙冠的错误处理是
七厘散的主治是
××省属亚热带温湿气候,夏季最高气温40℃,冬季最低气温-10℃。6~7月为梅雨季节,年平均降雨量在1234mm以上。11月至次年3月空气湿度较大,经常大雾弥漫,能见度极差。省内公路、铁路、内河航运十分便利。该省现有的大地控制网受地壳变动和社会建设发
下列选项中没有能够获取城市土地使用权的方式是()。
下列行为中属于合理使用的是()。
根据我国《公司法》规定,有限责任公司监事会可行使的职权包括()。
2006年1月1日,某企业以500万元向B公司投资,拥有B公司30%的股份。该企业对B公司投资的初始投资成本与应享有B公司所有者权益份额相等,该企业采用权益法核算此项股权投资。2006年B公司全年实现净利润120万元,2007年3月B公司宣告分派现金股利
=_______。
IseenoconflictinwhattheBibletellsmeaboutGodandwhatsciencetellsmeaboutnature.LikeSt.AugustineinA.D.400,
最新回复
(
0
)