1、三级数据库技术机试-191 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.程序 test.c的功能是:将大于整数 m且紧靠 m的 k个素数存入数组 xx。请考生编写函数 num(int m,int k,int xx)实现程序的要求,最后调用函数 readwriteDAT()把结果输出到 out.dat文件中。例如,若输入 17,5,则应输出:19,23,29,31,37。注意:部分源程序存在 test.c文件中。请勿改动数据文件 in.dat中的任何数据以及主函数 main()和输出函数 readwriteDAT()的内容。#includ
2、e stdio.h /include 语句说明各程序中包含 vc6.0中的标准输入输出库函数 stdio.hvoid readwriteDAT();/函数 readwriteDAT()说明语句int isP(int m) /函数 isP(int m)判断 m是否为素数,如果是素数则返回 1,否则返回 0int i; /定义变量 ifor (i=2; im; i+) /变量 i从 2依次递增到 m-1if (m % i=0) return 0; /如果 m能被 i整除,返回 0return 1; /否则返回 1void num(int m, int k, int xx)main()int m,
3、n, xx1000; /定义变量 m,n 和数组 xx1000printf(“/nPlease enter two integers:“);scanf(“%d, %d“, /从键盘读入两个数赋给变量 m,nnum (m,n,xx); /调用函数 num(int m,int k,int xx)实现将大于整数 m且紧靠 m的 k个素数存入数组 xxfor (m=0; mn; m+) /变量 m从 0依次递增到 n-1printf(“%d“,xxm); /输出数组元素 xxmprintf(“/n“); /输出一个回车换行符readwriteDAT();/调用函数 readwriteDAT()把结果输
4、出到 out.dat文件中void readwriteDAT()/函数 readwriteDAT()的定义语句int m,n,xx1000,i; /定义整型变量 m,n,i 和数组 xx1000FILE *rf,*wf; /定义文件指针变量 rf,wfrf=fopen(“in.dat“,“r“); /以只读的方式的打开文件 in.dat,并用 rf指向这个文件wf=fopen(“out.dat“,“w“); /以只写的方式的打开文件 out.dat,并用 wf指向这个文件for (i=0; i10; i+) /循环变量 i从 0依次递增到 9fscanf (rf,“%d%d“, /从文件 in
5、.dat读入两个数值赋给 m,nnum (m,n,xx);/调用函数函数 num(m,k,xx)实现将大于整数 m且紧靠 m的 k个素数存入数组 xxfor(m=0;mn; m+) /循环变量 m从 0依次递增到 n-1fprintf (wf,“%d“,xxm); /把数组元素 xxm写入到文件 out.dat中fprintf (wf,“/n“); /把回车换行符写入到文件 out.dat中fclose (rf); /关闭输入文件 in.datfclose (wf); /关闭输出文件 out.dat(分数:100.00)_三级数据库技术机试-191 答案解析(总分:100.00,做题时间:90
6、 分钟)一、上机题(总题数:1,分数:100.00)1.程序 test.c的功能是:将大于整数 m且紧靠 m的 k个素数存入数组 xx。请考生编写函数 num(int m,int k,int xx)实现程序的要求,最后调用函数 readwriteDAT()把结果输出到 out.dat文件中。例如,若输入 17,5,则应输出:19,23,29,31,37。注意:部分源程序存在 test.c文件中。请勿改动数据文件 in.dat中的任何数据以及主函数 main()和输出函数 readwriteDAT()的内容。#include stdio.h /include 语句说明各程序中包含 vc6.0中的
7、标准输入输出库函数 stdio.hvoid readwriteDAT();/函数 readwriteDAT()说明语句int isP(int m) /函数 isP(int m)判断 m是否为素数,如果是素数则返回 1,否则返回 0int i; /定义变量 ifor (i=2; im; i+) /变量 i从 2依次递增到 m-1if (m % i=0) return 0; /如果 m能被 i整除,返回 0return 1; /否则返回 1void num(int m, int k, int xx)main()int m, n, xx1000; /定义变量 m,n 和数组 xx1000printf
8、(“/nPlease enter two integers:“);scanf(“%d, %d“, /从键盘读入两个数赋给变量 m,nnum (m,n,xx); /调用函数 num(int m,int k,int xx)实现将大于整数 m且紧靠 m的 k个素数存入数组 xxfor (m=0; mn; m+) /变量 m从 0依次递增到 n-1printf(“%d“,xxm); /输出数组元素 xxmprintf(“/n“); /输出一个回车换行符readwriteDAT();/调用函数 readwriteDAT()把结果输出到 out.dat文件中void readwriteDAT()/函数 r
9、eadwriteDAT()的定义语句int m,n,xx1000,i; /定义整型变量 m,n,i 和数组 xx1000FILE *rf,*wf; /定义文件指针变量 rf,wfrf=fopen(“in.dat“,“r“); /以只读的方式的打开文件 in.dat,并用 rf指向这个文件wf=fopen(“out.dat“,“w“); /以只写的方式的打开文件 out.dat,并用 wf指向这个文件for (i=0; i10; i+) /循环变量 i从 0依次递增到 9fscanf (rf,“%d%d“, /从文件 in.dat读入两个数值赋给 m,nnum (m,n,xx);/调用函数函数
10、num(m,k,xx)实现将大于整数 m且紧靠 m的 k个素数存入数组 xxfor(m=0;mn; m+) /循环变量 m从 0依次递增到 n-1fprintf (wf,“%d“,xxm); /把数组元素 xxm写入到文件 out.dat中fprintf (wf,“/n“); /把回车换行符写入到文件 out.dat中fclose (rf); /关闭输入文件 in.datfclose (wf); /关闭输出文件 out.dat(分数:100.00)_正确答案:(int cnt=0; /定义变量 cnt并初值等于 0while (cntk) /当 cnt的值小于 k时m+; /变量 m加 1if
11、 (isP (m) xxcnt+=m; /如果 m为素数,则把其赋给数组元素 xxcnt,并且数组的下标 cnt加 1)解析:解析 将大于整数 m且紧靠 m的 k个素数存入数组。解题思路首先定义一个计数变量 cnt并赋初值为 0。利用 while循环统计大于整数 m且紧靠 m的 k个素数,当计数变量 cnt的值与变量 k的值相等的时候,则退出 while循环。每执行一次循环时,变量 m的值加 1,然后调用函数 isP()判断当前的 m值是否为素数,如果是素数,则将 m的值赋给数组 xxcnt,同时计算变量 cnt的值加 1,即当数组 xx0中保存了一个素数之后,在下一次素数判断成立时将保存到 xx1的位置上,依次类推。
copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1