电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本
换一换
首页 金锄头文库 > 资源分类 > DOCX文档下载
分享到微信 分享到微博 分享到QQ空间

2021年下半年程序员下午试卷_3

  • 资源ID:183325888       资源大小:192.89KB        全文页数:18页
  • 资源格式: DOCX        下载积分:10金贝
快捷下载 游客一键下载
账号登录下载
微信登录下载
三方登录下载: 微信开放平台登录   支付宝登录   QQ登录  
二维码
微信扫一扫登录
下载资源需要10金贝
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
如填写123,账号就是123,密码也是123。
支付方式: 支付宝    微信支付   
验证码:   换一换

 
账号:
密码:
验证码:   换一换
  忘记密码?
    
1、金锄头文库是“C2C”交易模式,即卖家上传的文档直接由买家下载,本站只是中间服务平台,本站所有文档下载所得的收益全部归上传人(卖家)所有,作为网络服务商,若您的权利被侵害请及时联系右侧客服;
2、如你看到网页展示的文档有jinchutou.com水印,是因预览和防盗链等技术需要对部份页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有jinchutou.com水印标识,下载后原文更清晰;
3、所有的PPT和DOC文档都被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;下载前须认真查看,确认无误后再购买;
4、文档大部份都是可以预览的,金锄头文库作为内容存储提供商,无法对各卖家所售文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;
5、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据;
6、如果您还有什么不清楚的或需要我们协助,可以点击右侧栏的客服。
下载须知 | 常见问题汇总

2021年下半年程序员下午试卷_3

2021年下半年程序员下午试卷1、【简答题】试题一(共15分)阅读以下说明和流程图,填补流程图中的空缺(1)(5),将解答填入答题纸的对应栏内。说明某单位动态收集的数据中常包含重复的数据,所以需要进行处理,使得重复的数据仅出现一次。下面流程图的功能是:在n(n1)个数据D1、D2、Dn中,选出其中所有不重复的k个数据,置于原来前k个数据的位置上。该流程图的算法如下:第1个数据必然被选出,然后从第2个数据开始,逐个考察其余的数据。假设D1、D2、Dm(m1)是已经选出的、不重复的数据,则对于数据Di(min),将其依次与Dm、Dm-1、D1进行比较,若没有发现与之相同者,则Di被选出并置于Dm+1的位置上;否则对Di不做处理。例如,如下10个数据:5,2,2,7,4,4,7,1,9,1(n=10)经过上述算法处理后的结果为:5,2,7,4,1,9(k=6)流程图注:循环开始的说明按照“循环变量名:循环初值,循环终值,增量”格式描述。15分解析:(1)1(2)2(3)m(4)Dm+1(5)mm+12、【简答题】试题二(共15分)阅读以下说明和C语言函数,将应填入(n)处的字句写在答题纸的对应栏内。说明已知1900年1月1日是星期一,下面的函数count_5_13(intyear)用于计算给定的年份year中有几个“黑色星期五”。“黑色星期五”指既是13日又是星期五的日期。函数count_5_13(intyear)首先算出年份year的1月13日是星期几,然后依次计算每个月的13日是星期几,若是星期五,则计数。程序中使用了函数isLeapYear(intyear),其功能是判断给定年份是否为闰年,返回值为1(或0)分别表示year是(或不是)闰年。C语言函数intcount_5_13(intyear)intdate;/*date为0表示星期日,为16分别表示星期一至星期六*/longdays=0;/*days记录天数*/intm,y,c=0;/*c用于表示黑色星期五的个数*/if(year1900)return-1;/*计算从1900年1月1日起,至给定年份year的1月13日间隔的天数*/days=12;for(y=1900;yyear;y+)days+=365;if(isLeapYear(y)(1);date=(days%7)+1)%7;/*算出给定年份year的1月13日是星期几*/c=((2))?1:0;for(m=1;(3);m+)switch(m)case1:case3:case5:case7:case8:case10:case12:days=31;break;case4:case6:case9:case11:days=30;break;case2:days=28;if((4))days=29;break;/*endofswitch*/date=(days%7)+(5))%7;if(date=5)c+;/*endoffor*/returnc;15分解析:(1)days+,days+=1,days=days+1(2)date=5(3)m12(4)isLeapYear(year)或year%4=0year%100!=0|year%400=0(5)date3、【简答题】试题三(共15分)阅读以下说明和C语言程序,将应填入(n)处的字句写在答题纸的对应栏内。说明某电信公司记录了每个用户的详细通话情况(每次通话数据记录在一行),现将某用户某月的通话数据存入一个文本文件“dial.txt”,其数据格式如下:拨入或拨出标记通话开始时间通话结束时间对方号码注1:数据字段以一个空格作为分隔符。注2:拨入和拨出标记均为小写字母。拨入标记为“i”,表示其他用户呼叫本机,本机用户不需付费;拨出标记为“o”,表示本机呼叫其他用户,此时本机用户需要付费。注3:通话开始和结束时间的格式均为:HH:MM:SS。其中HH表示小时,取值0023;MM表示分钟,取值0059;SS表示秒,取值0059。从通话开始到结束这段时间称为通话时间,假定每次通话时间以秒为单位,最短为1秒,最长不超过24小时。注4:跨月的通话记录计入下个月的通话数据文件。例如“o23:01:1200:12:15”表示本次通话是本机呼叫其他用户,时间从23时01分12秒至次日的0时12分15秒,通话时间为71分03秒。下面程序的功能是计算并输出该用户本月电话费(单位:元)。通话计费规则为:1.月通话费按每次通话费累加;2.每次的通话费按通话时间每分钟0.08元计算,不足1分钟时按1分钟计费。对于每次的拨出通话,程序中先分别计算出通话开始和结束时间相对于当日0点0分0秒的时间长度(以秒为单位),然后算出本次通话时间和通话费。例如,若输入文件dial.txt的数据如下所示,则输出fee=7.44。o14:05:2314:11:2582346789i15:10:0016:01:1513890000000o10:53:1211:07:0563000123o23:01:1200:12:1513356789001C程序代码#includestdio.hFILE*fin;intmain()charstr80;inth1,h2,m1,m2,s1,s2;longt_start,t_end,interval;intc;doublefee=0;fin=fopen("dial.txt","r");if(!fin)return-1;while(!feof(fin)if(!fgets(str,80,fin)break;if((1))continue;h1=(str2-48)*10+str3-48;m1=(str5-48)*10+str6-48;s1=(str8-48)*10+str9-48;h2=(str11-48)*10+str12-48;m2=(str14-48)*10+str15-48;s2=(str17-48)*10+str18-48;t_start=h1*60*60+m1*60+s1;/*通话开始时间*/t_end=h2*60*60+m2*60+s2;/*通话结束时间*/if((2))/*若通话开始和结束时间跨日*/interval=(3)-t_start+t_end;elseinterval=t_end-t_start;c=(4);/*计算完整分钟数表示的通话时间*/if(interval%60)(5);fee+=c*0.08;fclose(fin);printf("fee=%.2lfn",fee);return0;15分解析:(1)str0=i,或*str=i(2)t_endt_start(3)24*60*60(4)interval/60(5)c+,c+=1,c=c+14、【简答题】试题四(共15分)阅读以下说明和C语言函数,将应填入(n)处的字句写在答题纸的对应栏内。说明已知包含头结点(不存储元素)的单链表的元素已经按照非递减方式排序,函数compress(NODE*head)的功能是去掉其中重复的元素,使得链表中的元素互不相同。处理过程中,当元素重复出现时,保留元素第一次出现所在的结点。图4-1(a)、(b)是经函数compress()处理前后的链表结构示例图。链表的结点类型定义如下:typedefstructNodeintdata;structNode*next;NODE;C语言函数voidcompress(NODE*head)NODE*ptr,*q;ptr=(1);/*取得第一个元素结点的指针*/while((2)ptr-next)q=ptr-next;while(q(3))/*处理重复元素*/(4)=q-next;free(q);q=ptr-next;(5)=ptr-next;/*endofwhile*/*endofcompress*/15分解析:(1)head-next(2)ptr(3)q-data=ptr-data或ptr-next-data=ptr-data(4)ptr-next(5)ptr5、【简答题】试题五(共15分)阅读下列说明、图和C+代码,回答问题1至问题3,将解答写在答题纸的对应栏内。说明已知四个类之间的关系如图5-1所示,分别对每个类的方法进行编号,例如Shape的perimeter()方法为1号,表示为“1:perimeter()”,Rectangle类的perimeter()为2号,表示为“2:perimeter()”,依此类推,其中,每个类的perimeter方法都为虚函数且方法签名相同。C+代码Triangle*tr=newTriangle();Square*sq=newSquare();Shape*sh=tr;问题1关于上述C+代码中sh和tr的以下叙述中,哪两个是正确的(写出编号)。sh和tr分别引用同一个对象;sh和tr分别引用同一类型的不同的对象;sh和tr分别引用不同类型的不同对象;sh和tr分别引用同一个对象的不同拷贝;sh和tr所引用的内存空间是相同的。问题2写出下面消息对应的方法编号(如果该消息错误或者没有对应的方法调用,请填写“无”)。tr-height()(1)sh-perimeter()(2)sq-height()(3)sq-perimeter()(4)sh-height()(5)tr-perimeter()(6)问题3不考虑内存释放问题,下列赋值语句中哪两个是合法的(写出合法赋值语句的编号)。sq=sh;sh=tr;tr=sq;sq=tr;sh=sq;15分解析:问题1问题2(1)3(2)5(3)无(4)4(5)无(6)5问题36、【简答题】试题六(共15分)阅读以下应用说明以及VisualBasic程序代码,将应填入(n)处的字句写在答题纸的对应栏内。应用说明某电视台拟开发应用程序来显示戏曲大赛中14号四位选手决赛的现场投票情况。该程序从现场观众中(不超过2000人)每0.5秒收集一次对这四位选手的支持票数,并在屏幕上动态显示这四位选手的票柱(以高度反映票数)与累计得票数,如图6-1所示。投票过程限时30秒,每名观众最多为1名选手投票。投票结束后系统通过比较各位选手的累计得票数,显示决赛结果:“*号胜出”(如有单个冠军)或“继续进行PK”(如有多人获得相同的最高票数)。图6-1在开发该程序的过程中创建的主要控件及其初始属性值说明如下:该程序中设置公共变量T动态记录投票时间。四个形状ShpM(1to4)动态增长的底线固定。VisualBasic程序代码DimTAsInteger声明全局变量PrivateSubForm_Load()Fori=1To4ShpM(i).Top=2000:ShpM(i).He

注意事项

本文(2021年下半年程序员下午试卷_3)为本站会员(阳光****活)主动上传,金锄头文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即阅读金锄头文库的“版权提示”【网址:https://www.jinchutou.com/h-59.html】,按提示上传提交保证函及证明材料,经审查核实后我们立即给予删除!

温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.