中国教育在线 中国教育网 加入收藏 设为首页

2004年11月软考模拟试题(程序员下午试题)

http://itpx.eol.cn  来源:  作者:  2005-01-25    

试题一  阅读下列说明、流程图和算法,将应填入 n 处的字句写在答题纸的对应栏内。

[流程图说明]

    下面的流程图用N-S盒图形式描述了在一棵排序二叉树中查找元素的过程,节点有三个成员:dataleftright。其查找的方法是:首先与树的根节点的元素值进行比较:若相等则找到,返回此结点的地址;若要查找的元素小于根节点的元素值,则指针指向此结点的左子树,继续查找;若要查找的元素大于根节点的元素值,则指针指向此结点的游子树,继续查找。直到指针为空,表示此树中不存在所要查找的元素。

 

[算法说明]

       将上题的排序二叉树中查找元素的过程用递归的方法实现。其中NODE是自定义类型:

       typedef struct node {

              int data;

              struct node *left;

              struct node *right;

       } NODE;

[算法]

       NODE *SearchSortTree(NODE *tree,int e) {

              if(tree != NULL)

{     if (tree->data < e)

  (4)  ; //小于查找左子树

    else if (tree->data < e)

                                (5)  ;//大于查找左子树

                     else return tree;

              }

              return tree;

       }

试题二

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

[函数2.1说明]

函数strcat(char s[], char t[])的功能是:将字符串t复制连接字符串s的尾部,并返回新字符串的首地址作为函数值。例如:若s=abcd”,t=efg”,则新字符串应该是“abcdefg”。

[函数2.1]

char *strcat(char s[], char t[])

{     char *p;

       p = s + strlen(s)-1

       while(   (1)     ) {

                 (2)   ;

       }

       *p = ‘\0’;

       return s;

}

[函数2.2说明]

       函数f(char *str, char del)的功能是:将非空字符串str中的指定字符del删除,形成一个新字符串仍存放在str所指内存单元中。

       例如若str的值为“33123333435del的值为‘3,调用此函数后,新字符串为:“1245

[函数2.2]

void f(char *str, char del)

{

       int i, j, len;

       len=strlen(str);

       i=j=0;

       while(i<len) {

              if (    (3)    )

    (4)     = str[i];

              i++;

       }

            (5)    ;

}

试题三

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

[说明]

下面程序中函数fun的功能是:在含有10 个元素的s数组中查找最大数,及最大数所在位置(即,下标值),最大数可能不止一个。最大数作为函数值返回,最大数的个数通过指针变量n传回,所在位置由数组pos传回。

   例如:

        若输入 2 8 5 7 8 4 5 3 2 8

   则应输出:

          The max: 8

          Total: 3 //最大数出现次数

          The positions 1 4 9     

#include<stdio.h>

   #define M 10

   int fun(int *a, int *n, int pos[])

{   int i, k, max=-32767;

         (1)     

         for(i=0; i<M; i++)

         if(    (2)   ) max=a[i];

         for(i=0; i<M; i++)

                     if(   (3)   ) pos[k++]=i;

           *n=k;

      return max;

        }

     main()

 { int a[M], pos[M], i=0, j, n;

        printf("Enter 10 number :");

       for(i=0; i<M; i++)scanf("%d", 4);

          j=fun(     (5)     );

       printf("The max: %d\n", j);

       printf("Total: %d",n);

       printf("The position:");

        for(i=0; i<n; i++ ) printf("%4d", pos[i]);

       printf("\n");

        }

 

试题四  (试题四和试题五选做一题)

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

[函数说明]

  函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组dat(第行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组dat中,最后调用函数WriteDat()把结果dat输出到文件out.dat中。

  条件:从字符串中间一分为二,右边部分按字符的ASCII值降序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加排序,字符仍放在原位置上。

例如:位置                 0 1 2 3 4 5 6 7

源字符串               h g f e a b c d

则处理后字符串       d c b a h g f e

  部分源程序已给出。

  请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。

#include<stdio.h>

#include<string.h>

char dat[20][80];

void jsSort()

{     int i,j,k,strl;

       char ch;

       for(i=0;i<20;i++)

       {     strl=strlen(dat[i]);

              for(j=   (1)   ;j<strl;j++)//处理后半部分的字符串

                 for(k=j+1;k<strl;k++)

                  if(    (2)    )

                   {

                         ch=dat[i][j];

                         dat[i][j]=dat[i][k];

                         dat[i][k]=ch;

                   }

              for(j=0;     (3)     ;j++)

              {

                     ch=dat[i][j];

                     dat[i][j]=dat[i][(strl+1)/2+j];

                     dat[i][(strl+1)/2+j]=ch;

              }

       }

}

readDat()

{     FILE *in;

       int i=0;

       char *p;

            (4)     ;

       while(i<20&&fgets(dat[i],80,in)!=NULL)

       {     p=strchr(dat[i],’\n’);

              if(p)*p=0;

              i++;

       }

       fclose(in);

}

writeDat()

{     FILE *out;

       int i;

       out=fopen(“out.dat”,”w”);

       for(i=0;i<20;i++)

       {     printf(“%s\n” ,dat[i]);

              fprintf(    (5)    );

       }

       fclose(out);

}

void main()

{     readDat();

       jsSort();

       writeDat();

}

 

试题五 题是一个“加法计算器”应用程序,其界面及运行情况如下,请填空。

    在该界面中,“被加数”、“加数”以及“和数”等文字称为标签(Label),相应的三个输入输出数据框称为文本框(TextBox),此外还有三个命令按钮(CommandButton)。用户在被加数和加数相应的文本框内输入数据,再单击“加法”按钮,便能在“和数”对应的框中看到相加的结果。当用户单击“清除”按钮时,就会清除各文本框中的数据。当用户单击“关闭”按钮时就会关闭该窗口并退出应用程序。在文本框中输入数据时,用户可以进行一般的插入、修改和删除操作。

    各个对象、有关的属性名以及需要修改的属性值设计如下:

    对象        属性名      属性值   

    窗体       (名称)     frmAdder

               Caption      1  

    标签1      Caption      被加数

    标签2      Caption      加数

    标签3      Caption      和数     

    文本框1   (名称)      txt1

                Text        (空)

    文本框2    (名称)       txt2

                Text       

    文本框3   (名称)      txt3

                Text            

    按钮1      (名称)          2 

                Caption       加法

    按钮2     (名称)      cmdClear

                Caption      清除

    按钮3     (名称)      cmdClose

                Caption      关闭

    为该窗体中各个命令按钮的单击事件编写程序代码:

    Private Sub cmdAdd_Click()

       txt3.text=Str$(  3  )   '加法运算获得和数

    End Sub

    Private Sub  4  ()

       txt1.Text=""                    '空字符串赋值给文本框txt1的内容

       txt2.Text=""

       txt3.Text=""

    End Sub

    Private Sub cmdClose_Click()

         5                               '退出应用程序

    End Sub

 

 

试题六  (试题六和试题七选做一题)

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

[程序说明]

本程序从正文文件text.in中读入一篇英文短文,统计该短文中不同单词及出现次数,并按词典编辑顺序将单词及出现次数输出到正文文件word.out中。

程序用一棵有序二叉树存储这些单词及其出现的次数,边读入边建立,然后中序遍历该二叉树,将遍历经过的二叉树上的结点的内容输出。

# include <stdio.h>

# include <malloc.h>

# include <ctype.h>

# include <string.h>

# define   INF        "text.in"

# define   OUTF     "word.out"

typedef struct treenode {

       char *word;

       int    count;

       struct treenode *left, *right;

} BNODE;

int getword(FILE *fpt, char *word)

{     char c;

       c=fgetc(fpt);

       if ( c == EOF)

              return 0;

       while(!(tolower(c) >= 'a' && tolower(c) <= 'z'))

       {     c=fgetc(fpt);

              if ( c == EOF)

                     return 0;

       }  /* 跳过单词间的所有非字母字符 */

       while(tolower(c) >= 'a' && tolower(c) <= 'z')

       {     *word++ = c;

              c = fgetc(fpt);

       }

       *word = '\0';

       return 1;

}

void binary_tree(BNODE **t, char *word)

{     BNODE   *ptr, *p; int compres;

       p = NULL;   (1)  ;

       while (ptr)  /* 寻找插入位置 */

       {     compres=strcmp(word,   (2)   ); /* 保存当前比较结果 */

              if (!compres)

              {      (3)  ;  return; }

              else

              {       (4)  ;

                     ptr = compres>0 ? ptr->right : ptr->left;

              }

       }

       ptr = (BNODE *)malloc(sizeof(BNODE));

       ptr->left = ptr->right = NULL;

       ptr->word = (char *)malloc(strlen(word)+1);

       strcpy(ptr->word, word);

       ptr->count = 1;

       if (p == NULL)

                (5)  ;

       else if (compres > 0)

              p->right = ptr;

       else

              p->left = ptr;

}

void midorder(FILE *fpt, BNODE *t)

{     if ( t == NULL )

              return;

       midorder(fpt, t->left);

       fprintf(fpt, "%s %d\n", t->word, t->count);

       midorder(fpt, t->right);

}

void main()

{     FILE       *fpt;  char word[40];

       BNODE   *root=NULL;

       if ((fpt=fopen(INF, "r")) == NULL)

       {     printf("Can't open file %s\n", INF);

              return;

       }

       while(getword(fpt, word) == 1)

              binary_tree( &root, word );

       fclose(fpt);

       fpt = fopen(OUTF, "w");

       if (fpt == NULL)

       {     printf("Can't open file %s\n", OUTF);

              return;

       }

       midorder(fpt, root);

       fclose(fpt);

}

  

试题七

某单位职工情况数据库名为emp.mdb,其中含有一个数据表person,其表结构如下:

       字段名    数据类型     大小    缺省值    是否允许空值

       编号       Text         6      2004000          

       姓名       Text         8                    

       工资       Real                              

    现需要用VB开发一个应用程序,运行该应用程序就能够访问数据库emp.mdb,进行所需的数据库操作。用VB开发能访问数据库的应用程序,我们用两种方法实现。

1、利用“数据窗体设计器”自动生成数据窗体

 
 


设计步骤如下:

(1)          先利用VB中的可视化数据库管理器创建数据库emp.mdb以及其中的数据表person,输入数据内容。

(2)          在打开数据库emp.mdb的情况下(出现数据库窗口和SQL语句窗口),利用菜单“   1  ”,打开数据窗体设计器,填写窗体名称(如:职工情况表)、 2  (如:person);并利用中间的按钮,将左边的3个字段名全部移动右边;

(3)          利用“生成窗体”按钮生成数据窗体“frm职工情况表”。运行该窗体就能看到图10.11的界面。此时,用户非常容易进行各种数据操作。

2、利用数据控件访问数据库

   生成如下图所示的窗口。窗口下部有数据控件(命名为dataP),通过其左右各2个箭头可浏览上节创建的数据库emp中表person的各个记录,将其显示在各个文本框内。各个按钮可分别进行相应的数据记录操作。


    为使数据控件dataP与数据库emp中的表person相连接,需要设置dataP的属性如下:

      属性名         属性值                                          

      connect        Access     默认连接的数据库类型为Access

        (3)          emp        设置所需连接的数据库

    RecordSource      4     设置所需连接的数据源(表名,或SQL语句字符串)

    为使文本框与数据控件dataP相连接,并指明所需显示的字段名,需要设置文本框的如下属性:

      属性名         属性值                           

        (5)          dataP        设置所需连接的数据控件

DataField        字段名       设置所需连接的数据表字段名

 

 

程序员模拟试题1上午试题参考答案

1B           2 D      3 A        4 C      5 D

6A            7 C      8 C        9 A        10B

11D          12B        13A        14D        15C

16D          17B        18D        19B       20A

21C        22C      23C        24D        25C

26A         27D        28A       29C       30D

31B          32D       33D        34C        35D

36B          37A      38D        39D        40C

41A       42B      43A        44D      45C

46D        47B      48D      49C      50A

51B       52A      53A       54C      55B

56D      57C     58D    59B      60A

61D          62D        63C      64B      65C

66A       67C       68D     69B      70A

71A        72D      73B        74B      75A

 

程序员模拟试题1下午试题参考答案

试题一

(1) p p->left

       (2) p p->right

       (3) if (p->data == e) return p

       (4) return SearchSortTree(tree->left, int e)

       (5) return SearchSortTree(tree->right,int e)

 

试题二

1*t *t != 0 *t != ‘\0’ *t != NULL

2*s++ = *t++

3str[i] == del

4str[j++]

5str[j] = 0 str[j] ==‘\0’ str[j] == NULL

 

试题三

1k=0

2a[i]>max

3a[i]== max

4a+i &a[i]

5a,&n,pos

 

 

 

 

试题四

(1)  (strl+1)/2

(2)  dat[i][j]<dat[i][k]

(3)  j<strl/2

(4)  in=fopen(“in.dat”,”r”)

(5)  out, “ %s\n” ,dat[i]

 

试题五

(1)       加法计算器

(2)       cmdAdd

(3)       Val(txt1.Text)+Val(txt2.Text)

(4)       cmdClear_Click

(5)       End

 

试题六

(1)  ptr = *t

(2)  ptr->word   

(3)  ptr->count++

(4)  p=ptr

(5)  *t = ptr

 

试题七

(1)    实用程序—数据窗体设计器

(2)    记录源

(3)    DatabaseName

(4)    person

(5)    DataSource

 

出处:赛迪网校

推荐给好友    我要收藏    我要纠错    分享到

相关资讯

免责声明:

① 凡本站注明“稿件来源:中国教育在线”的所有文字、图片和音视频稿件,版权均属本网所有,任何媒体、网站或个人未经本网协议授权不得转载、链接、转贴或以其他方式复制发表。已经本站协议授权的媒体、网站,在下载使用时必须注明“稿件来源:中国教育在线”,违者本站将依法追究责任。

② 本站注明稿件来源为其他媒体的文/图等稿件均为转载稿,本站转载出于非商业性的教育和科研之目的,并不意味着赞同其观点或证实其内容的真实性。如转载稿涉及版权等问题,请作者在两周内速来电或来函联系。

内容推荐
eol.cn简介 | 联系方式 | 网站声明 | 京ICP证140769号 | 京ICP备12045350号 | 京公网安备 11010802020236号
版权所有 北京中教双元科技集团有限公司 EOL Corporation
Mail to: webmaster@eol.cn