软件水平考试真题
选课中心 APP下载
当前位置:首页 > 技能类 > 软件水平 > 考试真题 > 历年计算机的软考程序员笔试部分真题

历年计算机的软考程序员笔试部分真题

更新时间:2017-11-14 11:04:17 来源: 阅读量:

软件水平报名、考试、查分时间 免费短信提醒

广东

获取验证 立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

【摘要】 软考网权威发布历年计算机的软考程序员笔试部分真题,更多历年计算机的软考程序员笔试部分真题相关信息请访问计算机软件水平考试网。试题二

历年计算机的软考程序员笔试部分真题软考网权威发布历年计算机的软考程序员笔试部分真题,更多历年计算机的软考程序员笔试部分真题相关信息请访问计算机软件水平考试网。

试题二

  阅读下列函数说明和C函数,将应填入__(n)__处的字句写在答题纸的对应栏内。

[函数2.1说明]

  函数palindrome(chars[])的功能是:判断字符串s是否为回文字符串,若是,则返回0,否则返回-1。若一个字符串顺读和倒读都一样时,称该字符串是回文字符串,例如:“LEVEL”是回文字符串,而“LEVAL”不是。

[函数2.1]

 int palindrome(char S[]) { char *pi,*pj;  pi=S;pj=s+strlen(S)-1:  while ( pi

[函数2.2说明]

  函数f(char *str,char del)的功能是;将非空字符串str分割成若干个子字符串并输出,del表示分割时的标志字符。

  例如若str的值为“33123333435”,del的值为‘3’,调用此函数后,将输出三个子字符串,分别为“12”、“4”和“5”。

[函数2.2]

 void f(char*str,char del) { int i,j,len;  len = strlen(str);  i = 0;  while (i

试题三

  以下是与Visual Basic开发应用有关的5个问题.对每一个问题,请将解答填入答题纸的对应栏内。

  (1)在Visual Basic中,工程文件、窗体文件和标准模块文件的扩展名是什么?

  请从下列选项中选择:

  prg、prj、exe、vbp、rom、frm、win、fra,std、bas、vbs、Vbm

  (2)设某窗体上有一个命令按钮,其名称为 CmdSave,运行时该按钮上显示有“保存(S)”字样的信息。为使热键 ALT+S 与该命令按钮相关联,应该对按钮 CmdSave 的 Caption属性设置什么样的属性值?

  (3)设某窗口内有一个图像框 Image1,以及两个命令按钮“放大”和“缩小”。单击“放大”按钮就会使该图像框的长和宽都放大10%;单击“缩小”按钮就会使该图像框的长和宽都缩小10%(该图像框的左上角不动)。请分别写出这两个命令按钮的单击事件过程中的程序代码。

  (4)为使某个单选按钮初始时默认被选中,在开发时应怎样做?

  (5)若有语句 Tmpval=MsgBox(非法操作!,ybOKCancel+vbCritical,"提示"),请简要描述程序运行时弹出的消息框的主要特征。

从下列的2道试题(试题四至试题五)中任选1道解答,如果解答的试题数超过1道,则题号小的1道解咎有效。试题四

  阅读以下说明和C代码,将应填入__(n)__处的字句写在答题纸的对应栏内。

[说明]

  函数 MultibaseOutput(long n,int B)的功能是:将一个无符号十进制整数 n 转换成 B(2≤B≤16)进制数并输出。该函数先将转换过程中得到的各位数字入栈,转换结束后再把 B 进制数从栈中输出。有关栈操作的诸函数功能见相应函数中的注释。C代码中的符号常量及栈的类型定义如下:

 #define KAXSIZE 32 typedef struct{  int *elem;  /* 栈的存储区 */  int max;   /* 栈的容量,即找中最多能存放的元素个数 */  int top;   /* 栈顶指针 */  }Stack;[C代码] int lnitStack(Stack *S,int n)  /* 创建容量为n的空栈 */ { S->elem = (int *)matloc(n * sizeof(int));  if (S->elem == NULL) return -1;  S->max = n;__(1)__= 0;return 0; } int Push(Stack*S,int item)   /* 将整数item压入栈顶 */ { if(S->top == S->max){ printf("Stack is full!\n");return -1;}  __(2)__;item;return 0; } int StackEmpty(Stack S){ return(!S.top) ? 1;0;) /* 判断栈是否为空 */ int Pop(Stack*S)        /* 栈顶元素出栈 */ { if (!S->top){ printf("Pop an empty stack!\n");return -1;)  return __(3)__; } void MultibaseOutput(long n,int B) { int m;Stack S;  if (init Stack(&S,MAXSIZE)) { printf("Failure!\n");return;}  do {   if (Push(&s,__(4)__)) { printf("Failure!\n");return;}   n = __(5)__:  } while (n != 0);  while (!StackEmpty(S)) {     /* 输出B进制的数 */   m = Pop(&S);   if (m < 10) printf("Kd",m);  /* 小于10,输出数字 */   else printf("%c,m + 55);    /* 大于或等于10,输出相应的字符 */  }  printf("\n"); }

  从下列的2道试题(试题六至试题七)中任选1道解答。如果解答的试题数超过1道,则题号小的1道解答有效。试题六

  阅读下列函数说明和 C 函数,将应填入__(n)__处的字句写在答题纸的对应栏内。

[函数6说明]

  函数DelAInsB(LinkedList La,LinkedList lb,int key1,int key2,int len)的功能是,将线性表A中关键码为keyl的结点开始的len个结点,按原顺序移至线性表B中关键码为key2的结点之前,若移动成功,则返回0;否则返回-1。线性表的存储结构为带头结点的单链表,La为表A的头指针,Lb为表B的头指针。单链表结点的类型定义为:

 typedef struct node{  int key;  struct node*next; }*Linkedhist;

[函数6]

 int DelllnsB(LinkedLiSt La,LinkedList Lb,int keyl,int key2,int len) { LinkedList p,q,S,prep,pres;  int k;  if (!La->next || !Lb->next || len<=0) return-1;  p = La->next; prep = La;  while (p && p->key != keyl){   /* 查找表A中键值为key1的结点 */   prep = p; p = p->next;  }  if (!p) return -1;        /* 表A中不存在键值为key1的结点 */  q = p; k = 1;  while (q && __(1)__){       /* 在表A中找出待删除的len个结点 */   __(2)__: k++;  }  if (!q) return -1;        /* 表A中不存在要被删除的len个结点 */ ·  S = Lb->next;__ (3)__;  while (s && s->key != key2){   /* 查找表B中键值为key2的结点 */  pres = s; s = s->next;  }  if (!s)return -1;        /* 表B中不存在键值为key2的结点 */  __(4)__q->next;         /* 将表A中的len个结点删除 */  q->next:__(5)__  pres->next = p;         /* 将len个结点移至表B */  return 0; }

试题八

  阅读下列程序说明和C程序,将应填入__(n)__处的字句写在答题纸的对应栏内。

[程序8说明]

  程序8用于计算某公司每个职工应缴纳的个人所得税额和全体职工缴纳的个人所得税总额。职工的当月收入(工资或薪金)通过键盘输入,每次输入一个职工的工号和工资(或薪金)。由于该公司的工资或薪金是不定时发放的,所以输入过程中每个职工的收入会出现多次输入,整个输入以工号小于等于0结束。

  假设个人所得税法规定;个人收入所得,按月计税,以每月收入总额减除免税金额800元后的余额作为该月的月应纳税所得额,适用税率如下表所示。

  上表表明,个人收入所得税是按照超额累进的税率来征收的。

  设一个人的月应纳税所得额为K(元),用下面的公式计算其应缴纳的个人所得税额S(元):

  若0

  若500

  若2000

  若5000

  例如,某人某月工资总额为4100元,减去800元后,应纳税所得额为3300元,其应缴纳的个人所得税额为500*5%+1500*10%+1300*15%=370元。

[程序8]

 #include  #define MaxNum 50 #define BASE 800     /*免税金额基数*/ int paylevel[]={0,500,2000,5000,20000,40000,60000,80000,100000,100000¨: int taxPrate[]={5,10,15,20,25,30,35,40,45): /*税率表*/ typedef struct{  int ld;    /*职工的工号*/ .  long Salary;  /*职工的工资*/ }Info; /* 查找工号为Id的职工在数组employee中的下标,返回值为0表示没有 */ int find(int ld,Info employee[],int m){  int j;  employee[0].Id=Id;  for(j=m;__(1)__;j--);   return j; } void main(void) { Info employeeCHaxNum+1];  long Wage;  double sum s 0,K,S:  int i,j,N=0,Code;  scanf("M%ld",&Code,&Wage);   /*读入职工号、工资或薪金*/  while(Code>0) {   i=find(Code,employee,N);   if (i>0)employee[i].Salary += Wage:   else{ __ (2)__;   employee[N].Id=Code;employee[N].Salary=Wage;   }   scanf("%d%ld",&Code,&Wage):  }  for (i=1;i<=N;i++){   K = __(3)__;         /*计算月应纳税所得额*/   S=0;             /*月应纳税额赋初值*/   if (K > 0) {    for (j=1;j<=9;j++)     if(__(4)__)        /*月应纳税所得额超过第j级*/      S=S+(paylevel[j]-paylevel[j-1])*taxPrate[j-1]/100;     else{ S=S+(__ (5)__)*taxPrate[j-1]/100;break;}   }   printf("职工%d应缴纳的个人所得税额:%10.21f\n",employee[i].Id,S);   sum += S;  }  printf("全体职工个人所得税总额:%10,21f\n",sum); }

分享到: 编辑:admin