- 1、本文档共42页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
计算机等级考试必威体育精装版上机考试南开一百题2012版(完整解析版)
南开一百题2012版(完整解析版)
1、下列程序的功能是:将大于整数m且紧靠m的k个素数存入数组xx。请编写函数num(int m,int k,int xx[])实现函数的要求 ,最后调用函数readwriteDAT()把结果输出到文件out.dat中。
例如:若输入17,5,则应输出:19,23,29,31,37。
#include conio.h
#include stdio.h
void readwriteDAT() ;
int isP(int m)
{ int i ;
for(i = 2 ; i m ; i++)
if(m % i == 0) return 0 ;
return 1 ;
}
1:void num(int m,int k,int xx[])
{int data=m+1;
int half,n=0,I;
while(1)
{half=data/2;
for(I=2;I=half;I++)
if(data%I==0)break;
if(Ihalf)
{xx[n]=data;n++;}
if(n=k)break;
data++;
} }
或者:
void num(int m,int k,int xx[])
{int i,j,s=0;
for(i=m+1;k0;i++)
{for(j=2;ji;j++)
if(i%j==0) break; /*注:素数为只能被自己和1整除的数.如果i%j等于0,说明i不是素数,跳出本层循环*/
if(i==j)
{xx[s++]=i;k--;}
} }
void num(int m, int k, int xx[])
{ int i=0;
for(m=m+1;k0;m++)
if(isP(m))
{ xx[i++]=m;
k--; } }
main()
{ int m, n, xx[1000] ;
clrscr() ;
printf(\nPlease enter two integers:) ;
scanf(%d,%d, m, n ) ;
num(m, n, xx) ;
for(m = 0 ; m n ; m++)
printf(%d , xx[m]) ;
printf(\n) ;
readwriteDAT() ;
}
void readwriteDAT()
{ int m, n, xx[1000], i ;
FILE *rf, *wf ;
rf = fopen(in.dat, r) ;
wf = fopen(out.dat, w) ;
for(i = 0 ; i 10 ; i++) {
fscanf(rf, %d %d, m, n) ;
num(m, n, xx) ;
for(m = 0 ; m n ; m++) fprintf(wf, %d , xx[m]) ;
fprintf(wf, \n) ;
}
fclose(rf) ;
fclose(wf) ;
}
2、已知数据文件IN.DAT中存有200个四位数, 并已调用读函数readDat()把这些数存入数组a中,请考生编制一函数jsVal(),其功能是: 如果四位数各位上的数字均是0或2或4或6或8, 则统计出满足此条件的个数cnt, 并把这些四位数按从大到小的顺序存入数组b中。最后main()函数调用写函数writeDat( )把结果cnt以及数组b中符合条件的四位数输出到OUT.DAT文件中。
#include stdio.h
#define MAX 200
int a[MAX], b[MAX], cnt = 0;
2:void jsVal() /*标准答案*/
{int bb[4];
int I,j,k,flag;
for (I=0;I200;I++)
{bb[0]=a[I]/1000; bb[1]=a[I]%1000/100;
bb[2]=a[I]%100/10; bb[3]=a[I]%10;
for (j=0;j4;j++)
{if (bb[j]%2==0)
flag=1;
else
{flag=0;break;}
}
if (flag==1)
{ b[cnt]=a[I];
cnt++;} }
for(I=0;Icnt-1;I++)
for(j=I+1;jcnt;j++)
if (b[I]b[j])
{k=b[I];b[I]=b[j];b[j]=k;} }
void readDat()
{ int i ;
FIL
您可能关注的文档
最近下载
- 初中语文新课标教学设计及反思.pptx
- 就地型馈线自动化选型技术原则(试行).ppt
- 小学生交通安全知识竞赛课件.ppt
- 科技经费管理培训通用课件.ppt
- 激光模拟打靶技术方案.pptx
- 《思想政治教育方法论》PPT课件 2.第八章 课件 第八章《思想政治教育的一般方法》201812.pptx VIP
- 餐饮劳务外包合同(五篇).doc VIP
- 2023年成都信息工程大学数据科学与大数据技术专业《操作系统》科目期末试卷B(有答案).docx VIP
- 中小型企业局域网的规划与设计.doc VIP
- 2024-2025学年新教材高中英语 Unit 3 On the move理解 课文精研读教案 外研版必修第二册.docx
文档评论(0)