• 22.06 KB
  • 2021-05-14 发布

精编国家开放大学电大《数据结构》网络课形考网考作业及答案

  • 27页
  • 当前文档由用户上传发布,收益归属用户
  1. 1、本文档由用户上传,淘文库整理发布,可阅读全部内容。
  2. 2、本文档内容版权归属内容提供方,所产生的收益全部归内容提供方所有。如果您对本文有版权争议,请立即联系网站客服。
  3. 3、本文档由用户上传,本站不保证质量和数量令人满意,可能有诸多瑕疵,付费之前,请仔细阅读内容确认后进行付费下载。
  4. 网站客服QQ:403074932
国家开放大学电大《数据结构》网络课形考网考作业及答案 ‎ 国家开放大学电大《数据结构》网络课形考网考作业及答案 100%通过 考试说明:2020年秋期电大把该网络课纳入到“国开平台”进行考核,该课程共有4个形考任务,针对该门课程,本人汇总了该科所有的题,形成一个完整的标准题库,并且以后会不断更新,对考生的复习、作业和考试起着非常重要的作用,会给您节省大量的时间。做考题时,利用本文档中的查找工具,把考题中的关键字输到查找工具的查找内容框内,就可迅速查找到该题答案。本文库还有其他网核及教学考一体化答案,敬请查看。​ 课程总成绩 = 形成性考核×50% + 终结性考试×50% 形考任务1 一、单项选择题(每小题3分,共60分)题目1 把数据存储到计算机中,并具体体现数据元素间的逻辑结构称为( )。 选择一项:A. 算法的具体实现 B. 逻辑结构 C. 给相关变量分配存储单元 D. 物理结构 题目2 下列说法中,不正确的是( )。 选择一项:A. 数据项是数据中不可分割的最小可标识单位 B. 数据元素是数据的基本单位 C. 数据项可由若干个数据元素构成 D. 数据可有若干个数据元素构成 题目3 一个存储结点存储一个( )。 ‎ ‎ 选择一项:A. 数据项 B. 数据类型 C. 数据元素 D. 数据结构 题目4 数据结构中,与所使用的计算机无关的是数据的( )。 选择一项:A. 存储结构 B. 物理结构 C. 逻辑结构 D. 物理和存储结构 题目5 在线性表的顺序结构中,以下说法正确的是( )。 选择一项:A. 进行数据元素的插入、删除效率较高 B. 数据元素是不能随机访问的 C. 逻辑上相邻的元素在物理位置上不一定相邻 D. 逻辑上相邻的元素在物理位置上也相邻 题目6 对链表, 以下叙述中正确的是( )。 选择一项:A. 可以通过下标对链表进行直接访问 B. 插入删除元素的操作一定要要移动结点 C. 不能随机访问任一结点 D. 结点占用的存储空间是连续的 题目7 下列的叙述中,不属于算法特性的是( )。 选择一项:A. 可行性 B. 有穷性 C. 可读性 D. 输入性 题目8 算法的时间复杂度与( )有关。 选择一项:A. 所使用的计算机 B. 计算机的操作系统 C. 数据结构 D. 算法本身 题目9 ‎ 设有一个长度为n的顺序表,要在第i个元素之前(也就是插入元素作为新表的第i个元素),插入一个元素,则移动元素个数为( )。 选择一项:A. n-i-1 B. i C. n-i+1 D. n-i 题目10 设有一个长度为n的顺序表,要删除第i个元素移动元素的个数为( )。 选择一项:A. i B. n-i-1 C. n-i D. n-i+1 题目11 在一个单链表中,p、q分别指向表中两个相邻的结点,且q所指结点是p所指结点的直接后继,现要删除q所指结点,可用语句( )。 选择一项:A. p->next=q->next B. p->next=q C. p=q->next D. q->next=NULL 题目12 在一个单链表中p所指结点之后插入一个s所指的结点时,可执行( )。 选择一项:A. p->next=s->next; B. s->next=p->next; p->next=s; C. p=s->next D. p->next= s; s->next= p->next 题目13 非空的单向循环链表的尾结点满足( )(设头指针为head,指针p指向尾结点)。 选择一项:A. p->next==NULL B. p->next==head C. p== head D. p==NULL 题目14 链表不具有的特点是( )。 选择一项:A. 逻辑上相邻的元素在物理位置上不一定相邻 B. 不必事先估计存储空间 C. 可随机访问任一元素 ‎ D. 插入删除不需要移动元素 题目15 带头结点的链表为空的判断条件是( )(设头指针为head)。 选择一项:A. head->next==head B. head->next==NULL C. head ==NULL D. head!=NULL 题目16 在一个长度为n的顺序表中为了删除第5个元素,由第6个元素开始从后到前依次移动了15个元素。则原顺序表的长度为( )。 选择一项:A. 21 B. 25 C. 20 D. 19 题目17 有关线性表的正确说法是( )。 选择一项:A. 除了一个和最后一个元素外,其余元素都有一个且仅有一个直接前驱和一个直接后继 B. 每个元素都有一个直接前驱和一个直接后继 C. 表中的元素必须按由小到大或由大到下排序 D. 线性表至少要求一个元素 题目18 向一个有127个元素的顺序表中插入一个新元素,并保持原来的顺序不变,平均要移动( )个元素。 选择一项:A. 7 B. 63 C. 63.5 D. 8 题目19 一个顺序表第一个元素的存储地址是90,每个元素的长度为2,则第6个元素的地址是( )。 选择一项:A. 102 B. 106 C. 100 D. 98 题目20 ‎ 在一个不带头结点的单循环链表中,p、q分别指向表中第一个结点和尾结点,现要删除第一个结点,且p、q仍然分别指向新表中第一个结点和尾结点。可用的语句是p=p->next;和( )。 选择一项:A. p->next=q B. q->next=p C. p=q->next D. q=p 二、判断题( 每小题2分,14题,共28分)题目21 数据元素可以有一个或多个数据项组成。 选择一项:对 错 题目22 数据元素之间的抽象关系称为物理结构。 选择一项:对 错 题目23 数据的逻辑结构在计算机中的表示称为逻辑结构。 选择一项:对 错 题目24 数据的逻辑结构是与存储该结构的计算机相关的。 选择一项:对 错 题目25 数据结构中,元素之间存在多对多的关系称为树状结构。 选择一项:对 错 题目26 通常可以把一本含有不同章节的书的目录结构抽象成线性结构。 选择一项:对 错 题目27 通常可以把某城市中各公交站点间的线路图抽象成树型结构。 选择一项:对 错 题目28 设有一个不带头结点的单向循环链表,结点的指针域为next,指针p指向尾结点,现要使p指向第一个结点,可用语句p=p->next;。 选择一项:对 错 题目29 ‎ ‎ 设有一个单向链表,结点的指针域为next,头指针为head,p指向尾结点,为了使该单向链表改为单向循环链表,可用语句p->next=head 。 选择一项:对 错 题目30 设有一个单向循环链表,结点的指针域为next,头指针为head,指针p指向表中某结点,若逻辑表达式p->next==head;的结果为真,则p所指结点为尾结点。 选择一项:对 错 题目31 要在一个单向链表中p所指向的结点之后插入一个s所指向的新结点,若链表中结点的指针域为next,可执行 p->next=s; s->next= p->next;的操作。 选择一项:对 错 题目32 要在一个单向链表中删除p所指向的结点,已知q指向p所指结点的直接前驱结点,若链表中结点的指针域为next,则可执行q->next= p->next;选择一项:对 错 题目33 要在一个带头结点的单向循环链表中删除头结点,得到一个新的不带头结点的单向循环链表,若结点的指针域为next,头指针为head,尾指针为p,则可执行head=head-> next; p->next=head;。 选择一项:对 错 题目34 ‎ 设有一个单向循环链表,头指针为head,链表中结点的指针域为next,p指向尾结点的直接前驱结点,若要删除尾结点,得到一个新的单向循环链表,可执行操作p->next=head;。 选择一项:对 错 三、程序填空题(每小题6分,共12分。请点击正确选项,然后拖拽至相应的方框上)题目35 设线性表以不带头结点的单向链表存储,链表头指针为head,以下程序的功能是输出链表中各结点中的数据域data,完成程序中空格部分。 #define NULL 0 void main( ) { NODE *head ,*p ; p=head; /*p为工作指针*/ do {printf(“%d\n”, ; ; }while ; } p‑>datap=p‑>next p!=NULL 题目36 设有一个头指针为head的不带头结点单向链表,p、q是指向链表中结点类型的指针变量,p指向链表中结点a, ‎ ‎(设链表中没有结点的数据域与结点a的数据域相同),写出相关语句 (1)使该单向链表成为单向循环链表 (2)插入结点s,使它成为a结点的直接前驱 q=p; x=p->data; while )q=q->next; q->next=head; q=p; p=p->next; while(p->data!=x) { q=p; } s->next=p; 形考任务2 一、单项选择题(每小题2分,共50分)题目1 若让元素1,2,3依次进栈,则出栈顺序不可能为( )。 选择一项:A. 3,1,2 B. 3,2,1 C. 2,1,3 D. 1,3,2 题目2 一个队列的入队序列是1,2,3,4。则队列的输出序列是( )。 选择一项:A. 1,4,3,2 B. 4,3,2,1 C. 3,2,4,1 D. 1,2,3,4 题目3 向顺序栈中压入新元素时,应当( )。 选择一项:A. 先后次序无关紧要 B. 先存入元素,再移动栈顶指针 C. 同时进行 D. 先移动栈顶指针,再存入元素 题目4 在一个栈顶指针为top的链栈中,将一个p指针所指的结点入栈,应执行( )。 选择一项:A. p->next=top->next;top->next=p; B. ‎ p->next=top->next;top=top->next; C. p->next=top;top=p; D. top->next=p; 题目5 在一个栈顶指针为top的链栈中删除一个结点时,用 x保存被删结点的值,则执行( )。 选择一项:A. x=top->data;top=top->next; B. top=top->next;x=top->data; C. x=top->data; D. x=top;top=top->next; 题目6 判断一个顺序队列(最多元素为m)为空的条件是( )。 选择一项:A. front==rear B. front==rear+1 C. rear==m-1 D. rear=m 题目7 判断一个循环队列为满的条件是( )。 选择一项:A. rear=MaxSize B. (rear+1)%MaxSize==front C. front==rear+1 D. rear%MaxSize= =front 题目8 判断栈满(元素个数最多n个)的条件是( )。 选择一项:A. top==n-1 B. top=-1 C. top!=0 D. top==0 题目9 设有一个20阶的对称矩阵A(第一个元素为a1,1),采用压缩存储的方式,将其下三角部分以行序为主序存储到一维数组B中(数组下标从1开始), 则矩阵元素a6,2在一维数组B中的下标是( )。 选择一项:A. 17 B. 28 C. 21 D. 23 题目10 ‎ 在解决计算机主机与打印机之间速度不匹配问题时通常设置一个打印数据缓冲区,主机将要输出的数据依次写入缓冲区中,而打印机则从缓冲区中取出数据打印,该缓冲区应该是一个( )结构。 选择一项:A. 数组 B. 堆栈 C. 线性表 D. 队列 题目11 一个递归算法必须包括( )。 选择一项:A. 终止条件和迭代部分 B. 递归部分 C. 迭代部分 D. 终止条件和递归部分 题目12 在一个链队中,假设f和r分别为队头和队尾指针,则删除一个结点的运算为( )。 选择一项:A. f=f->next; B. r=r->next; C. r=f->next; D. f=r->next; 题目13 在一个链队中,假设f和r分别为队头和队尾指针,则插入s所指结点的运算为( )。 选择一项:A. r->next=s;r=s; B. s->next=f;f=s; C. s->next=r;r=s; D. f->next=s;f=s; 题目14 数组a经初始化char a[ ]=“English”;a[7]中存放的是( )。 选择一项:A. “h“ B. 字符h C. 字符串的结束符 D. 变量h 题目15 设主串为“ABcCDABcdEFaBc”,以下模式串能与主串成功匹配的是( )。 选择一项:A. BCd B. ABC C. Bcd D. Abc 题目16 字符串 ‎ a1=“AEIJING“,a2=“AEI“,a3=“AEFANG“,a4=“AEFI“中最大的是( )。 选择一项:A. a4 B. a1 C. a3 D. a2 题目17 两个字符串相等的条件是( )。 选择一项:A. 两串包含的字符相同 B. 两串的长度相等 C. 两串的长度相等,并且两串包含的字符相同 D. 两串的长度相等,并且对应位置上的字符相同 题目18 一维数组A采用顺序存储结构,每个元素占用6个字节,第6个元素的存储地址为100,则该数组的首地址是( )。 选择一项:A. 70 B. 28 C. 90 D. 64 题目19 一个非空广义表的表头( )。 选择一项:A. 只能是原子 B. 可以是子表或原子 C. 不可能是原子 D. 只能是子表 题目20 对稀疏矩阵进行压缩存储,可采用三元组表,一个10 行8列的稀疏矩阵A,其相应的三元组表共有6个元素,矩阵A共有( )个零元素。 选择一项:A. 10 B. 74 C. 8 D. 72 题目21 对稀疏矩阵进行压缩存储,可采用三元组表,一个10 行8列的稀疏矩阵A共有73个零元素,A的右下角元素为6,其相应的三元组表中的第7个元素是( )。 选择一项:A. (10,8,6) B. (10,8,7)C. (7,8,10)D. (7,10,8)题目22 对一个栈顶指针为top的链栈进行入栈操作,通过指针变量p生成入栈结点,并给该 ‎ 结点赋值a,则执行: p=(struct node *)malloc(sizeof(struct node);p->data=a;和( )。 选择一项:A. p->next=top;top=p; B. top->next=p;p=top; C. p->next=top;p=top; D. top=top->next;p=top; 题目23 头指针为head的带头结点的单向链表为空的判定条件是( )为真。 选择一项:A. head==NULL B. head->next==NULL C. head->next!=NULL D. head->next!=NULL 题目24 设有一个对称矩阵A,采用压缩存储的方式,将其下三角部分以行序为主序存储到一维数组B中(数组下标从1开始),B数组共有55个元素,则该矩阵是( )阶的对称矩阵。 选择一项:A. 10 B. 5 C. 15 D. 20 题目25 数组a经初始化char a[ ]=“English”;a[1]中存放的是( )。 选择一项:A. “n“ B. “E“ C. 字符n D. 字符E 二、判断题(每小题2分,16题,共32分 )题目26 设有一个链栈,栈顶指针为hs,现有一个s所指向的结点要入栈,则可执行操作。hs=s;s-> next=hs; 选择一项:对 错 题目27 设有一个非空的链栈,栈顶指针为hs,要进行出栈操作,用x保存出栈结点的值,栈 结点的指针域为next,则可执行hs=hs->next ;x=hs->data; 选择一项:对 错 ‎ 题目28 有一个链栈,栈顶指针为h,现有一个p所指向的结点要入栈,则可执行操作p->next=h; 和h=p;选择一项:对 错 题目29 设有一个非空的链栈,栈顶指针为hs,要进行出栈操作,用x保存出栈结点的值,栈结点的指针域为next,数据域为data,则可执行hs= hs->next; x= hs->data; 选择一项:对 错 题目30 在一个链队中,f和r分别为队头和队尾指针,队结点的指针域为next,则插入所指结点的操作为r->next=s;r=s;选择一项:对 错 题目31 在一个链队中,f和r分别为队头和队尾指针,队结点的指针域为next,s指向一个要入 队的结点,则入队操作为r=s;r->next=s;选择一项:对 错 题目32 在一个不带头结点的非空链队中,f和r分别为队头和队尾指针,队结点的数据域为data,指针域为next,若要进行出队操作,并用变量x存放出队元素的数据值,则相关操作为x=f->data; f=f->next; 选择一项:对 错 题目33 对稀疏矩阵进行压缩存储,可采用三元组表,一个6行7列的稀疏矩阵A相应的三元组表共有8个元素,则矩阵A共有34个零元素。 选择一项:对 错 题目34 ‎ ‎ 循环队列的最大存储空间为MaxSize,队头指针为f,队尾指针为r,当(r+1)%MaxSize=f 时表明队列已满。 选择一项:对 错 题目35 循环队列的队头指针为f,队尾指针为r,当r= =f时表明队列已满。 选择一项:对 错 题目36 空串的长度是0;空格串的长度是空格字符的个数。 选择一项:对 错 题目37 对稀疏矩阵进行压缩存储,矩阵中每个非零元素对应的三元组包括该元素的行下标、列下标、和非零元素值三项信息。 选择一项:对 错 题目38 循环队列的引入,目的是为了克服假上溢。 选择一项:对 错 题目39 设有n阶对称矩阵A,用一维数组s压缩存储A的下三角元素,s的下标从零开始,元素 s[26]相应于A中的元素为a 7,5。 选择一项:对 错 题目40 循环队列的最大存储空间为MaxSize=6,采用少用一个元素空间以有效的判断栈空或栈满,若队头指针front=4,当队尾指针rear=3时队满。 选择一项:对 错 题目41 ‎ 循环队列的最大存储空间为MaxSize=6,采用少用一个元素空间以有效的判断栈空或栈满,若队头指针front=4,队尾指针rear=3时,队列中共有5个元素。 选择一项:对 错 三、程序选择填空题(每小题9分,共18分。请点击正确选项,然后拖拽至相应的方框上)题目42 以下函数为链栈的进栈操作,x是要进栈的结点的数据域,top为栈顶指针 struct node { ElemType data; struct node *next; }; struct node *top ; void Push(ElemType x) { struct node *p; p=(struct node*)malloc ; p->data=x; ‎ ‎ ; ; } A.sizeof (struct node) top=p p‑>next=top 题目43 以下函数为链队列的入队操作,x为要入队的结点的数据域的值,front、rear分别链队列的队头、队尾指针 ‎ struct node { ElemType data; struct node *next; }; struct node *front,*rear; void InQueue(ElemType x) { struct node *p; p= (struct node*) malloc ; p->data=x; p->next=NULL; ‎ ‎ ; rear= ; } 形考任务3 一、单项选择题(每小题2分,共38分)题目1 假定一棵二叉树中,双分支结点数为15,单分支结点数为30,则叶子结点数为( )。 选择一项:A. 47 B. 16 C. 17 D. 15 题目2 二叉树第k层上最多有( )个结点。 ‎ ‎ 选择一项:A. 2k-1 B. 2k-1 C. 2k-1 D. 2k 题目3 将含有150个结点的完全二叉树从根这一层开始,每一层从左到右依次对结点进行编号,根结点的编号为1,则编号为69的结点的双亲结点的编号为( )。 选择一项:A. 36 B. 35 C. 34 D. 33 题目4 如果将给定的一组数据作为叶子数值,所构造出的二叉树的带权路径长度最小,则该树称为( )。 选择一项:A. 二叉树 B. 哈夫曼树 C. 完全二叉树 D. 平衡二叉树 题目5 在一棵度具有5层的满二叉树中结点总数为( )。 选择一项:A. 16 B. 32 C. 31 D. 33 题目6 一棵完全二叉树共有6层,且第6层上有6个结点,该树共有( )个结点。 选择一项:A. 31 B. 37 C. 38 D. 72 题目7 利用3、6、8、12这四个值作为叶子结点的权,生成一棵哈夫曼树,该树中所有叶子结点中的最长带权路径长度为( )。 选择一项:A. 18 B. 16 C. 30 D. 12 题目8 在一棵树中,( )没有前驱结点。 选择一项:A. 树根结点 B. 叶结点 C. 空结点 D. 分支结点 题目9 设一棵采用链式存储的二叉树,除叶结点外每个结点度数都为2,该树结点中共有20个指针域为空,则该树有( ‎ ‎ )个叶结点。 选择一项:A. 9 B. 10 C. 21 D. 22 题目10 在一个图G中,所有顶点的度数之和等于所有边数之和的( )倍。 选择一项:A. 2 B. 1 C. 4 D. 1/2 题目11 邻接表是图的一种( )。 选择一项:A. 链式存储结构 B. 顺序存储结构 C. 散列存储结构 D. 索引存储结构 题目12 图的深度优先遍历算法类似于二叉树的( )遍历。 选择一项:A. 先序 B. 后序 C. 层次 D. 中序 题目13 已知下图所示的一个图,若从顶点V1出发,按深度优先搜索法进行遍历,则可能得到的一种顶点序列为( )。 选择一项:A. V1V2V4V5V8V3V6V7 B. V1V3V6V7V2V4V5V8 C. V1V2V4V8V3V5V6V7 D. V1V2V4V8V5V3V6V7 题目14 已知如下图所示的一个图,若从顶点a出发,按广度优先搜索法进行遍历,则可能得到的一种顶点序列为( )。 选择一项:A. aedfcb B. abecdf C. aebcfd D. aecbdf 题目15 图状结构中数据元素的位置之间存在( )的关系。 选择一项:A. 一对多 B. 多对多 C. 每一个元素都有一个且只有一个直接前驱和一个直接后继 D. 一对一 ‎ 题目16 在一棵二叉树中,若编号为i的结点存在右孩子,则右孩子的顺序编号为( )。 选择一项:A. 2i+1 B. 2i-1 C. 2i D. 2i+2 题目17 一棵具有16个结点的完全二叉树,共有( )层。(设根结点在第一层) 选择一项:A. 7 B. 5 C. 6 D. 4 题目18 对二叉排序树进行( )遍历,可以使遍历所得到的序列是有序序列。 选择一项:A. 按层次 B. 中序 C. 前序 D. 后序 题目19 已知一个图的边数为m,则该图的所有顶点的度数之和为( )。 选择一项:A. m/2 B. m C. 2m D. 2m+1 二、判断题 (每小题1分,共10分)题目20 一棵二叉树的叶结点(终端结点)数为5,单分支结点数为2,该树共有11个结点。 选择一项:对 错 题目21 一棵有14个结点的完全二叉树,则它的最高层上有7个结点。 选择一项:对 错 题目22 一棵二叉树有6个叶结点,则该树总共有11个结点。 选择一项:对 错 题目23 根据搜索方法的不同,图的遍历有.先序;中序;后序三种方法。 选择一项:对 错 题目24 对于一棵具有n个结点的二叉树,其相应的链式存储结构中共有n-1个指针域空。 ‎ ‎ 选择一项:对 错 题目25 设一棵完全二叉树,其最高层上最右边的叶结点的编号为奇数,该叶结点的双亲结点的编号为10,该完全二叉树一共有21个结点。 选择一项:对 错 题目26 设一棵完全二叉树,其最高层上最右边的叶结点的编号为偶数,该叶结点的双亲结点的编号为9,该完全二叉树一共有19个结点。 选择一项:对 错 题目27 按照二叉树的递归定义,对二叉树遍历的常用算法有深度优先遍历和深度优先遍两种方法。 选择一项:对 错 题目28 一棵有8个权重值构造的哈夫曼数,共有17个结点。 选择一项:对 错 题目29 一棵有7个叶结点的二叉树,其1度结点数的个数为2,则该树共有15个结点。 选择一项:对 错 三、程序填空题(每空6分,共12分。请点击正确选项,然后拖拽至相应的方框上)题目30 以下程序是后序遍历二叉树的递归算法的程序,完成程序中空格部分(树结构中左、右指针域分别为left和right,数据域data为字符型,BT指向根结点)。完成程序中空格部分。 题目31 ‎ 以下程序是中序遍历二叉树的递归算法的程序,完成程序中空格部分(树结构中左、右指针域分别为left和right,数据域data为字符型,BT指向根结点)。 四、综合应用题(每小题8分,5题,共40分)题目32 题目33 题目34 题目35 题目36 形考任务4 一、单项选择题(每小题2分,共40分)题目1 对线性表进行二分查找时,要求线性表必须( )。 选择一项:A. 以链接存储方式 B. 以链接存储方式,且数据元素有序 C. 以顺序存储方式 D. 以顺序存储方式,且数据元素有序 题目2 采用顺序查找方法查找长度为n的线性表时,每个元素的平均查找长度为( )。 选择一项:A. n B. (n-1)/2 C. n/2 D. (n+1)/2 题目3 有一个长度为10的有序表,按折半查找对该表进行查找,在等概率情况下查找成功的平均比较次数为( )。 选择一项:A. 29/9 B. 29/10 C. 26/10 D. 31/10 题目4 已知一个有序表为{11,22,33,44,55,66,77,88,99},则顺序查找元素55需要比较( )次。 选择一项:A. 6 B. 3 C. 5 D. 4 题目5 有数据{53,30,37,12,45,24,96},从空二叉树开始逐个插入数据来形成二叉排序树,若希望高度最小,应该选择的序列是( )。 选择一项:A. 12,24,30,37,45,53,96 B. 30,24,12,37,45,96,53 C. 45,24,53,12,37,96,30 D. 37,24,12,30,53,45,96 题目6 ‎ 对于顺序存储的有序表{5,12,20,26,37,42,46,50,64},若采用折半查找,则查找元素26的比较次数是( )。 选择一项:A. 4 B. 6 C. 3 D. 5 题目7 在所有的排序方法中,关键字比较的次数与记录初始排列秩序无关的是( )。 选择一项:A. 希尔排序 B. 直接选择排序 C. 冒泡排序 D. 直接插入排序 题目8 从未排序序列中依次取出元素与已经排好序的序列中的元素作比较。将其放入已排序序列的正确的位置上,此方法称为( )。 选择一项:A. 插入排序 B. 选择排序 C. 归并排序 D. 交换排序 题目9 依次将每两个相邻的有序表合并成一个有序表的排序方法称为( )。 选择一项:A. 交换排序 B. 归并排序 C. 插入排序 D. 选择排序 题目10 当两个元素出现逆序的时候就交换位置,这种排序方法称为( )。 选择一项:A. 选择排序 B. 插入排序 C. 归并排序 D. 交换排序 题目11 每次把待排序的区间划分为左、右两个子区间,其中左区间中记录的关键字均小于等于基准记录的关键字,右区间中记录的关键字均大于等于基准记录的关键字,这种排序称为( )。 选择一项:A. 插入排序 B. 快速排序 C. 堆排序 D. 归并排序 题目12 ‎ 一组记录的关键字序列为(46,20,30,79,56,38,40,84,90,110),利用快速排序,以第一个关键字为分割元素,经过一次划分后结果为( )。 选择一项:A. 40,20,30,38,46,56,79,84,90,110 B. 20,30 38,40,46,56,79,84,90,100 C. 20,30,40,38,46,79,56,84,90,100 D. 30,20,40,38,46,84,56,79,90,100 题目13 在有序表{10,14,34,43,47,64,75,80,90}中,用折半查找法查找值80时,经( )次比较后查找成功。 选择一项:A. 5 B. 3 C. 2 D. 4 题目14 对序列(49,38,65,97,76,13,47,50)采用直接插入排序法进行排序,要把第七个元素47插入到已排序中,为寻找插入的合适位置需要进行( )次元素间的比较。 选择一项:A. 3 B. 4 C. 6 D. 5 题目15 排序方法中,从未排序序列中挑选元素,并将其依次放入已排序序列(初始为空)的一端的方法,称为( )排序。 选择一项:A. 插入 B. 快速 C. 归并 D. 选择 题目16 一组记录的关键字序列为(26,59,36,18,20,25),利用堆排序的方法建立的初始小根堆为( )。 选择一项:A. 26,18,59,20,36,25 B. 18,20,25,59,26,36 C. 18,20,36,59,26,25 D. 26,59,36,18,20,25 题目17 ‎ 一组记录的关键字序列为(25,48,16,35,79,82,23,40,36,72),其中,含有5个长度为2的有序表,按归并排序的方法对该序列进行一趟归并后的结果为( )。 选择一项:A. 16,25,35,48,79,23,36,40,82,72 B. 16,25,35,48,23,40,79,82,36,72 C. 16,25,48,35,79,82,23,36,40,72 D. 16,25,35,48,79,82,23,36,40,72 题目18 已知10个数据元素为(54,28,16,34,73,62,95,60,26,43),对该数列从小到大排序,经过一趟冒泡排序后的序列为( )。 选择一项:A. 16,28,34,54,62,60,73,26,43,95 B. 28,16,34,54,62,73,60,26,43,95 C. 16,28,34,54,73,62,60,26,43,95 D. 28,16,34,54,62,60,73,26,43,95 题目19 一组记录的关键字序列为(46,79,56,38,40,84),利用快速排序,以第一个关键字为分割元素,经过一次划分后结果为( )。 选择一项:A. 40,38,46,84,56,79 B. 40,38,46,79,56,84 C. 38,40,46,56,79,84 D. 40,38,46,56,79,84 题目20 一组记录的关键字序列为(80,57,41,39,46,47),利用堆排序(堆顶元素是最小元素)的方法建立的初始堆为( )。 选择一项:A. 39,80,46,47,41,57 B. 39,46,41,57,80,47 C. 41,39,46,47,57,80 D. ‎ ‎39,47,46,80,41,57 二、程序填空题(每题10分,2题,共20分。请点击正确选项,然后拖拽至相应的方框上)题目21 以下函数是二叉排序树的查找算法,若二叉树为空,则返回根结点的指针,否则,返回值是指向树结点的结构指针p(查找成功p指向查到的树结点,不成功p指向为NULL)完成程序中的空格 题目22 以下程序是折半插入排序的算法 设待排序的记录序列存放在a[1],…a[n]中,以a[0]作为辅助工作单元,程序是要把a[i] 插入到已经有序的序列a[1],…a[i-1]中。 三、综合题(每小题8分,共40分)题目23 题目24 题目25 题目26 题目27‎