[计算机类试卷]国家三级(网络技术)机试模拟试卷266及答案与解析.doc
《[计算机类试卷]国家三级(网络技术)机试模拟试卷266及答案与解析.doc》由会员分享,可在线阅读,更多相关《[计算机类试卷]国家三级(网络技术)机试模拟试卷266及答案与解析.doc(3页珍藏版)》请在麦多课文档分享上搜索。
1、国家三级(网络技术)机试模拟试卷 266及答案与解析 一、程序设计题 1 请编制函数 int findValue(int outBuf),其功能是;在三位整数 (100 999)中寻找符合下面条件的整数,并依次从小到大存人数组 b中;它既是完全平方数,又有两位数字相同,例如 144, 676等。 满足该条件的整数的个数通过所编制的函数返回。 最后调用函数 WriteData(int num, int b)把结果输出到文件 OUT DAT中。 注意;部分源程序已给出。 请勿改动主函数 main()和写函数 WriteData()的内容。 试题程序; #include void WriteData
2、(int, int b); int findValue(int outBuf) void main() int b20, hum; num=findValue(b); WriteData(hum, b); void WriteData(int num, int b) FILE*out; int i; out=fopen(“OUT DAT“, “w“); printf(“num= d n“, num); fprintflout, “num= d n“, num); for(i=0; ihum; i+) printf(“b d= dn“, i, bi); fprintf(out, “b d= d
3、n“, i, bi); fclose(out); 国家三级(网络技术)机试模拟试卷 266答案与解析 一、程序设计题 1 【正确答案】 int findValue(int outBuf) int i, dl, d2, d3, count=0; for(i=10; i*i1000; i+) dl=i*i 100; 求该平方数的百位数字 d2=i*i 10 10; 求该平方数的十位数字 d3=i*i 10; 求该平方数的个位数字 if(d1=d2|d2=d3|d3=d1) outBufcount+=i*i; return count; 【试题解析】 本题主要考查数位分解及排 序。基本思路是;由于最小的三位数100是 10的平方,因此可以从 10开始,判断每个数的平方值是否有两位数字相同,直到找到数的平方值大于 999,这样既可遍历 100 999中所有的平方数,循环中将满足条件的数存入数组 outBuf中,由于遍历是从小到大的,因此数组outBuf中的元素已经按升序排列。
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
2000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 试卷 国家 三级 网络技术 模拟 266 答案 解析 DOC
