请编写函数num(int m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m的k个素数存入数组xx传回。 最后调用函数readwriteDat(),从in.dat文件中读取10组数据,分别得出结果,且把结果输出到out.dat文件中。 部分程序已经给出。 例如,若输入17 5,则应输出:19 23 29 31 37。 注意:部分程序已经给出。 请勿改动主函数main()和输出数据函数readwriteDat()的内容。 #include <conio.h> #include <stdio.h> void readwriteDat(); void num(int m,int k,int xx[]) { } main() { int m,n,xx[1000]; 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); fprintf(wf,"%d",xx[m]); fprintf(wf,"\n"); } fclose(rf); fclose(wf); }
在in.dat文件中有200个正整数,且每个数均在1000~9999之间。函数ReadDat()读取这200个数并存放到数组aa中。请编写函数jsSort(),其函数的功能是:要求按每个数的后三位的大小进行升序排列,然后取出满足此条件的前10个数依次存入数组bb中,如果后三位的数值相等,则按原先的数值进行降序排列。最后调用函数WriteDat(),把结果bb输出到out.dat文件中。 例如:处理前6012 5099 9012 7025 8088 处理后9012 6012 7025 8088 5099 注意:部分程序已经给出。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include <stdio.h> #include <string.h> #include <conio.h> int aa[200],bb[10]; void jsSort() { } void ReadDat() { FILE *in; int i; in=fopen("in.dat","r"); for(i=0;i<200;i++) fscanf(in,"%d,",&aa[i]); fclose(in); } void WriteDat() { FILE *out; int i; out=fopen("out.dat","w"); for(i=0;i<10;i++) { printf("%d",bb[i]); fprintf(out,"%d\n",bb[i]); } fclose(out); } void main() { ReadDat(); jsSort(); WriteDat(); }