- 1、本文档共40页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
1、下列程序的功能是将大于整数m且紧靠m的k个素数存入.doc
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 ;
FILE *fp ;
fp = fo
您可能关注的文档
- (2013.10.11)C++语言程序设计课程教学研讨(文本).doc
- (2014.04.10)Flash动画制作教研活动(文本).doc
- (32个控制字符,96个图形字符)见ASCII码表包括10个.ppt
- (k,b为常数,k不为零)的形式,则称y是x的一次函数x为自变.ppt
- 06-07学年第二学期无机期中试卷.doc
- 1.18对数函数一、素质教育目标(一)知识教学点1.对数函数.ppt
- 1.5分子间力和氢键.ppt
- 1.6.电子结构方法复习.ppt
- 1.一次函数y=kx+b的自变量的取值范围是-3≤x≤6,相应函数值.doc
- 1.在考生文件夹下,要求程序PROG.C的功能是.doc
- 新高考生物二轮复习讲练测第6讲 遗传的分子基础(检测) (原卷版).docx
- 新高考生物二轮复习讲练测第12讲 生物与环境(检测)(原卷版).docx
- 新高考生物二轮复习讲练测第3讲 酶和ATP(检测)(原卷版).docx
- 新高考生物二轮复习讲练测第9讲 神经调节与体液调节(检测)(原卷版).docx
- 新高考生物二轮复习讲练测第11讲 植物生命活动的调节(讲练)(原卷版).docx
- 新高考生物二轮复习讲练测第8讲 生物的变异、育种与进化(检测)(原卷版).docx
- 新高考生物二轮复习讲练测第5讲 细胞的分裂、分化、衰老和死亡(讲练)(原卷版).docx
- 新高考生物二轮复习讲练测第5讲 细胞的分裂、分化、衰老和死亡(检测)(原卷版).docx
- 新高考生物二轮复习讲练测第12讲 生物与环境(讲练)(原卷版).docx
- 新高考生物二轮复习讲练测第11讲 植物生命活动的调节(检测)(原卷版).docx
文档评论(0)