• 网络学院
  • IT资讯
  • 操作系统
  • 网络技术
  • 软件应用
  • 办公软件
  • 编程技术
  • 网站架设
  • 数据库类
  • 平面设计
  • 多媒体类
  • 游戏资讯
  • 教学论文
  • 认证考试
赛迪网校11月软考模拟试题程序员下午
  站点:
  • 首 页
  • 最新软件
  • 文章教程
  • 国内软件
  • 国外软件
  • 绿色软件
  • 源码下载
  • 字体下载
赛迪网校11月软考模拟试题程序员下午
软件发布 赛迪网校11月软考模拟试题程序员下午
网络软件 系统工具 应用软件 联络聊天 图形图像 多媒体类 行业软件 游戏娱乐 编程开发 安全相关 教育教学 数码软件 绿软下载
热门软件: QQ 瑞星 pplive e话通 木马克星 千千静听 office2000 五笔字根 Photoshop 视频分割
返回文章教程首页 >> 文章首页 >> 认证考试 >> 程序员 >> 赛迪网校11月软考模拟试题程序员下午

赛迪网校11月软考模拟试题程序员下午

添加时间: 2007-4-9 0:40:30  作者: 程序员认证参考  阅读次数:43   来源: http://www.d9soft.com

       

(程序员下午试题)
为了帮助学员检测自己的学习及复习情况,赛迪网校特意请软考界权威辅导教师为学员出仿真模拟试题若干套,供大家检验自测自己的学习情况。考生欲参考更多模拟试题及练习题请登录赛迪网校。
试题一  阅读下列说明、流程图和算法,将应填入 n 处的字句写在答题纸的对应栏内。
[流程图说明]
 下面的流程图用n-s盒图形式描述了在一棵排序二叉树中查找元素的过程,节点有三个成员:data,left,right。其查找的方法是:首先与树的根节点的元素值进行比较:若相等则找到,返回此结点的地址;若要查找的元素小于根节点的元素值,则指针指向此结点的左子树,继续查找;若要查找的元素大于根节点的元素值,则指针指向此结点的游子树,继续查找。直到指针为空,表示此树中不存在所要查找的元素。
[流程图]

[算法说明]
 将上题的排序二叉树中查找元素的过程用递归的方法实现。其中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 = '';
 return s;
}
[函数2.2说明]
 函数f(char *str, char del)的功能是:将非空字符串str中的指定字符del删除,形成一个新字符串仍存放在str所指内存单元中。
 例如若str的值为“33123333435”,del的值为‘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)    ;
}#p#
试题三
 阅读以下说明和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 ", j);
       printf("total: %d",n);
       printf("the position:");
       for(i=0; i<n; i++ ) printf("%4d", pos[i]);
       printf(" ");
  }

试题四  (试题四和试题五选做一题)
 阅读下列函数说明和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],' ');
  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 " ,dat[i]);
  fprintf(    (5)    );
 }
 fclose(out);
}
void main()
{ readdat();
 jssort();
 writedat();
}#p#

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

文字称为标签(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 = '';
 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 ", 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 ", 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 ", outf);
  return;
 }
 midorder(fpt, root);
 fclose(fpt);
}#p#

试题七
某单位职工情况数据库名为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        字段名       设置所需连接的数据表字段名

 

上下文章:

 

上一篇文章: C++程序员成长中最常走的4条弯路 下一篇文章: DirectX8.0简介(3)

相关文章:

  • 史上最强的几道oracle面试题
  • 国外公司的Oracle DBA试题
  • 今年4月三级数据库笔试试题及答案
  • Oracle DBA 逻辑备份试题选
  • 国外某公司的Oracle DBA试题

相关软件:

  • 全国计算机等级考试模拟软件(2006年全年使用)二级Visual Basic V9.0
  • 白金模拟炒股平台 V3.6
  • 全国计算机等级考试第21次全真模拟系统 20050311
  • 全国专业技术人员计算机应用能力考试模拟 2.1
  • 中考物理试卷分类试题 4.1
  • 计算机等级考试训练模拟软件(三级网络技术) V1.04

 

快速导航

  • 网络学院
  • 精品汇聚
  • 字体下载
  • 教程下载
  • ASP源码
  • PHP源码
  • Net源码
  • JSP 源码

认证考试分类导航

  • 微软认证
  • 计算机等级考试
  • 软件水平考试
  • 思科认证
  • Oracle认证
  • Linux认证
  • JAVA认证
  • 网络工程师
  • 系统工程师
  • 程序员

本类经典文章推荐

  • 软考系统分析师考试须知
  • C++箴言:绝不在构造或析构期调用...
  • 数据结构:判别是否为二叉排序树的...
  • 一个程序员的成长的六个阶段
  • 程序员英语试题常见硬件名和设备名
  • 从一个程序出发详细研究DataReader
  • 如何判断程序处于运行环境还是调试...
  • 程序高手必读:写好C程序的10条秘...
  • 程序员介绍:程序员的“素质”是什...
  • C++箴言:让=返回一个*this的引用

程序员阅读排行

  • 数据结构:判别是否为二叉排序树的...
  • VC++动态链接库(DLL)编程深入浅出...
  • VC++动态链接库(DLL)编程深入浅出...
  • 程序员考试:证书样本
  • 补码加、减运算规则及溢出判断
  • 数据结构:栈和递归求两顶点所有简...
  • DirectX8.0简介(8)
  • 水滴石穿·C语言之代码检查工...
  • 数据结构:打印线索二叉树的中序遍...
  • DirectX8.0简介(3)

认证考试阅读总排行

  • 全国计算机等级考试一级模拟试题01
  • 全国计算机等级考试一级模拟试题10
  • 全国计算机等级考试一级模拟试题08
  • MCSD简介
  • 全国计算机等级考试一级考试最新模...
  • 全国计算机等级考试一级模拟试题07
  • 全国计算机等级考试一级模拟试题02
  • 全国计算机等级考试一级模拟试题06
  • 全国计算机等级考试一级模拟试题03
  • 一级(WINDOWS)试题解析-Word篇

广告位置

字母检索 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 回到顶部

关于我们 | 版权声明 | 免责条款 | 广告联系 | 软件发布 | 下载帮助 | 下载排行 | 网站地图 | 特别鸣谢 | 友情连接

copyright; 2005-2008 D9soft.com 第九软件网 版权所有