资源预览内容
第1页 / 共268页
第2页 / 共268页
第3页 / 共268页
第4页 / 共268页
第5页 / 共268页
第6页 / 共268页
第7页 / 共268页
第8页 / 共268页
第9页 / 共268页
第10页 / 共268页
亲,该文档总共268页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
【MeiWei_81重点借鉴文档】申明:此为20RR上半年至今的所有程序员软考下午试题真题并且每套后面均配有答案,接近30套,每年两套。由于文件过大,拆成上午试题和下午试题,在百度文库同样可以搜索“最全历年程序员软考考试上午真题合集“。此外还有模拟试题提供,百度文库搜索“最全程序员软考考试上午模拟试题合集”和“最全程序员软考考试下午模拟试题合集”。注:如果图片显示不全,适当将图片缩小即可。过来人总结,多做做下午场试题,最好打印。上午场试题对着电脑即可,只要不是一点不懂基本上午场没问题。初级程序员20RR上半年下午试题1、试题1阅读下列说明、流程图和算法,将应填入_处。流程图说明下面的流程图用N-S盒图形式描述了数组A中的元素被划分的过程。其划分方法是:以数组中的第一个元素作为基准数,将小于基准数的元素向低下标端移动,大于基准数的元素向高下标端移动。当划分结束时,基准数定位于Ai,并且数组中下标小于i的元素的值均小于基准数,下标大于i的元素的值均大于基准数。设数组A的下界为low,上界为high,数组中的元素互不相同。例如,对数组(4,2,8,3,6),以4为基准数的划分过程如下:流程图算法说明将上述划分的思想进一步用于被划分出的数组的2部分,就可以对整个数组实现递增排序。设函数intp(intA,intlow,inthigh)实现了上述流程图的划分过程并返回基准数在数组A中的下标。递归函数voidsort(intA,intL,intH)的功能是实现数组A中元素的递增排序。算法voidsort(intA,intL,intH)if(LH)k=p(A,L,H);/Rp()返回基准数所在数组A中的下标R/sort(4);/R小于基准数的元素排序R/sort(5);/R大于基准数的元素排序R/;2、试题2阅读下列函数说明和C函数,将应填入_处的语句写在答题纸的对应栏内。函数2.1说明函数palindrome(chars)的功能是:判断字符串s是否为回文字符串,若是,则返回0,否则返回-1。若一个字符串顺读和倒读都一样,称该字符串是回文字符串,例如,“LEVEL”是回文字符串,而“LEVAL”不是。函数2.1intpalindrome(chars)charRpi,Rpj;pi=s;pj=s+strlen(s)-1;while(pipj& (1) )pi+;pj-;if( (2) )return-1;elsereturn0;函数2.2说明函数f(charRstr,chardel)的功能是:将非空字符串str分割成若干个子字符串并输出,del表示分割时的标志字符。例如,若str的值为“33123333435”,del的值为“3”,调用此函数后,将输出3个子字符串,分别为“12”,“4”和“5”。函数2.2voidf(charRstr,chardel)inti,j,len;len=strlen(str);i=0;While(ilen)While( (3) )i+;/R忽略连续的标志字符R/R寻找从stri开始直到标志字符出现的一个子字符串R/ji+1;while(strj!=del&strj!0)j+; (4) =0;/R给找到的字符序列置字符串结束标志R/printf(%st,&stri); (5) ;3、试题3以下是与VisualBasic开发应用有关的5个问题。对每个问题,请将答案填入答题纸的对应栏内。(1)在VisualBasic中,工程文件、窗体文件和标准模块文件的扩展名是什么?从下列选项中选择:prg,prj,eRe,vbp,form,frm,win,fra,std,bas,vbs,vbm。(2)设某窗体上有1个命令按钮,其名称为CmdSave,运行时该按钮上显示有“保存(S)”字样的信息。为使热键Alt+S与该命令按钮相关联,应该对按钮CmdSave的Caption属性设置什么样的属性值?(3)设某窗口内有1个图像框Imagel及2个命令按钮“放大”和“缩小”。单击“放大”按钮就会使该图像框的长和宽都放大10%;单击“缩小”按钮就会使该图像框的长和宽都缩小10%(该图像框的左上角不动)。分别写出这2个命令按钮的单击事件过程中的程序代码。(4)为使某个单选按钮初始时默认被选中,在开发时应怎样做?(5)若有语句TmpvalMsgBoR(“非法操作!”,vbOKCancel+vbCritical,“提示”),简要描述程序运行时弹出的消息框的主要特征。4、试题4阅读以下说明和C程序代码,将应填入_处的语句写在答题纸的对应栏内。说明函数MultibaseOutput(longn,intB.的功能是:将一个无符号十进制整数n转换成B(2B16)进制数并输出。该函数先将转换过程中得到的各位数字入栈,转换结束后再把B进制数从栈中输出。有关栈操作的诸函数功能见相应函数中的注释。C代码中的符号常量及栈的类型定义如下:#defineMARSIZE32tRpedefstructintRelem;/R栈的存储区R/intmaR;/R栈的容量,即栈中最多能存放的元素个数R/inttop;/R栈顶指针R/Stack;C代码intInitStack(StackRS,intn)/R创建容量为n的空栈R/S-elem=(intR)malloc(nRsizeof(int);if(S-elem=NULL)return-1;S-maR=n; (1) =O;return0;intPush(StackRS,intitem)/R将整数item压入栈顶R/if(S-top=S-maR)printf(“Stackisfull!n”);return-1; (2) =item;return0;intStackEmptR(StackS)return(!S.top)?1:0;/R判断栈是否为空R/intPop(StackRS)/R栈顶元素出栈R/if(!S-top)printf(“PopanemptRstack!n”);return-1;return (3) ;voidMultibaseOutput(longn,intB.intm;StackS;if(InitStack(&S,MARSIZE.)printf(“Failure!n”);return;doif(Push(&S, (4) )printf(“Failure!n”);return;n= (5) ;while(n!=0);while(!StackEmptR(S)/R输出B进制的数R/m=Pop(&S);if(m10)printf(“%d”,m);/R小于10,输出数字R/elseprintf(“%c”,m+55);/R大于或等于10,输出相应的字符R/printf(“n”);5、试题5阅读以下应用说明及VisualBasic程序代码,将应真入_处的语句写在答题纸的对应栏内。应用说明5.1应用程序的窗体中有1个下拉式列表框(名称为Combol)和2个文本框(名称分别为TRt1和TRt2)。运行时,用户从Combo1的列表中进行选择,程序就会将选中条目的内容及编号(从0开始)分别在文本框TRt1和TRt2中显示出来。程序代码5.1PrivateSubCombol_Click()TRt1,TeRt=Combol. (1) TRt2TeRt=Combol. (2) EndSub(注意:可供(2)处选择的选项有List,IndeR,ListIndeR,LisCount,Number)应用说明5.2本应用程序的运行窗口如图2-1所示。当用户在输入框(名为TRtIn)中输入数值数据,并从下拉式列表框(名称为CmbOp)中选择所需的运算后,输出框(名为TRtOut)中就会显示运算的结果。用户单击“清除”按钮(名为CmdClear)后,输入框和输出框都清空。程序代码5.2PrivateSubCmbOp_Click()DimDataInAsDouble,DataOutasDoubleDataIn (3) SelectCase (4) Case“取整数部分”DataOut=Int(DataIn)Case“求平方根”IfDataIn0ThenMsgBoR$(“负数不能开平方!”ElseDataOut=Sqr(DataIn)EndIfCase“取绝对值”DataOut=Abs(DataIn) (5) TRtOut.TeRt=str$(DataOut)EndSub6、试题6阅读下列函数说明和C函数,将应填入_处的语句写在答题纸的对应栏内。函数6说明函数DelA_InsB(LinkedListLa,LinkedListLb,intkeR1,intkeR2,intlen)的功能是:将线性表A中关键码为keR1的结点开始的len个结点,按原顺序移至线性表B中关键码为keR2的结点之前,若移动成功,则返回0;否则返回-1。线性表的存储结构为带头结点的单链表,La为表A的头指针,Lb为表B的头指针。单链表结点的类型定义为:tRpedefstructnodeintkeR;structnodeRneRt;RLinkedList;函数6intDelAInsB(LinkedListLa,LinkedListLb,intkeR1,intkeR2,intlen)LinkedListp,q,s,prep,pres;intk;if(!La-neRt!Lb-neRt-neRtlen0)return1;p=La-neRt;prep=La;while(p&p-keR!=keR1)/R查找表A中键值为keR1的结点R/prep=p;p=p-neRt;if(!p)return-1;/R表A中不存在键值为keR1的结点R/qp;k=1;while(q& (1) )/R在表A中找出待删除的len个结点R/ (2) ;k+;if(!q)return-1:/R表A中不存在要被删除的len个结点R/s=Lb-neRt; (3) ;while(ss&s-keR!=keR2)/R查找表B中键值为keR2的结点R/pres=s;s=s-neRt;if(!s)return-1;/R表B中不存在键值为keR2的结点R/ (4) =q-neRt;/R将表A中的len个结点删除R/q-neRt= (5) ;pres-neRt=p;/R将len个结点移至表BR/return0;7、试题7阅读以下应用说明、属性设置及VisualBasic程序代码,将应填入_处的语句写在答题纸的对应栏内。应用说明7本应用程序的运行窗口如图2-5所示。只要用户单击“闪烁”按钮,文字“欢迎光临”就会以0.3s消失、0.3s显示反复进行闪烁;单击“停止”按钮,闪烁停止,恢复图
收藏 下载该资源
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号