|
发表于 2022-3-17 08:09:02
|
显示全部楼层
define NULL 0
void main( )
{ NODE *head ,*p ;
p=head; /*p 为工作指针*/
do
{printf(“%d\n”, [[1]];
[[2]];
}while[[3]];
}
; [[1]] -> {p->data / p=p->next / p!=NULL}"
"题目 36: 设有一个头指针为 head 的不带头结点单向链表,p、q 是指向链表中结
点类型的指针变量,p 指向链表中结点 a, (设链表中没有结点的数据域与结点 a 的数据
域相同),写出相关语句
(1)使该单向链表成为单向循环链表
(2)插入结点 s,使它成为 a 结点的直接前驱
q=p; x=p->data;
while [[3]])q=q->next;
q->next=head;
q=p; p=p->next;
while(p->data!=x)
{ q=p;
[[1]]
}
s->next=p;
[[2]]
; [[1]] -> {p=p->next / q->next=s / q->next!=NULL}"
电大数据结构(本)形考作业 2-阶段性学习测验 2 答案
"题目 1:若让元素 1,2,3 依次进栈,则出栈顺序不可能为( )。
: 3,2,1
; 3,1,2
; 1,3,2
; 2,1,3"
"题目 2:一个队列的入队序列是 1,2,3,4。则队列的输出序列是( )。
: 1,2,3,4
; 1,4,3,2
; 4,3,2,1
; 3,2,4,1"
"题目 3:向顺序栈中压入新元素时,应当( )。
: 先移动栈顶指针,再存入元素
; 先后次序雅关紧要
; 先存入元素,再移动栈顶指针
; 同时进行"
"题目 4:在一个栈顶指针为 top 的链栈中,将一个 p 指针所指的结点入栈,应执行
( )。
: p->next=top->next;top->next=p;
; p->next=top;top=p;
; top->next=p;
; p->next=top->next;top=top->next;"
"题目 5:在一个栈顶指针为 top 的链栈中删除一个结点时,用 x 保存被删结点的值,则
执行( )。
: x=top;top=top->next;
; x=top->data;
; x=top->data;top=top->next;
; top=top->next;x=top->data;"
"题目 6:判断一个顺序队列(最多元素为 m)为空的条件是( )。
: rear==m-1
; front==rear+1
; rear=m
; front==rear"
"题目 7:判断一个循环队列为满的条件是( )。
: front==rear+1
; rear=MaxSize
; (rear+1)%MaxSize==front
; rear%MaxSize= =front"
"题目 8:判断栈满(元素个数最多 n 个)的条件是( )。
: top==n-1
; top!=0
; top=-1
; top==0"
"题目 9:设有一个 20 阶的对称矩阵 A(第一个元素为 a1,1),采用压缩存储的方式,将
其下三角部分以行序为主序存储到一维数组 B 中(数组下标从 1 开始), 则矩阵元素
a6,2 在一维数组 B 中的下标是( )。
: 21
; 17
; 23
; 28"
"题目 10:在解决计算机主机与打印机之间速度不匹配问题时通常设置一个打印数据缓冲
区,主机将要输出的数据依次写入缓冲区中,而打印机则从缓冲区中取出数据打印,该缓
冲区应该是一个( )结构。
: 线性表
; 队列
; 数组
; 堆栈"
"题目 11:一个递归算法必须包括( )。
: 迭代部分
; 终止条件和迭代部分
; 递归部分
; 终止条件和递归部分"
"题目 12:在一个链队中,假设 f 和 r 分别为队头和队尾指针,则删除一个结点的运算为
( )。
: r=r->next;
; f=f->next;
; f=r->next;
; r=f->next;"
"题目 13:在一个链队中,假设 f 和 r 分别为队头和队尾指针,则插入 s 所指结点的运算
为( )。
: f->next=s;f=s;
; r->next=s;r=s;
; s->next=f;f=s;
; s->next=r;r=s;"
"题目 14:数组 a 经初始化 char a[ ]=“English”;a[7]中存放的是( )。
: 字符串的结束符
; 变量 h
; "h"
; 字符 h"
"题目 15:设主串为“ABcCDABcdEFaBc”,以下模式串能与主串成功匹配的是( )。
: Bcd
; Abc
; BCd
; ABC"
"题目 16:字符串 a1="AEIJING",a2="AEI",a3="AEFANG",a4="AEFI"中最大的是
( )。
: a2
; a1
; a4
; a3"
"题目 17:两个字符串相等的条件是( )。
: 两串的长度相等,并且两串包含的字符相同
; 两串的长度相等,并且对应位置上的字符相同
; 两串包含的字符相同
; 两串的长度相等"
"题目 18:一维数组 A 采用顺序存储结构,每个元素占用 6 个字节,第 6 个元素的存储地
址为 100,则该数组的首地址是( )。
: 28
; 64
; 90
; 70"
"题目 19:一个非空广义表的表头( )。
: 只能是原子
; 不可能是原子
; 可以是子表或原子
; 只能是子表"
"题目 20:对稀疏矩阵进行压缩存储,可采用三元组表,一个 10 行 8 列的稀疏矩阵 A,其
相应的三元组表共有 6 个元素,矩阵 A 共有( )个零元素。
: 10
; 72
; 74
; 8"
"题目 21:对稀疏矩阵进行压缩存储,可采用三元组表,一个 10 行 8 列的稀疏矩阵 A 共有
73 个零元素,A 的右下角元素为 6,其相应的三元组表中的第 7 个元素是( )。
: (10,8,7)
; (7,8,10)
; (10,8,6)
; (7,10,8)"
"题目 22:对一个栈顶指针为 top 的链栈进行入栈操作,通过指针变量 p 生成入栈结点,
并给该 结点赋值 a,则执行: p=(struct node *)malloc(sizeof(struct node);p-
>data=a;和( )。
: p->next=top;p=top;
; p->next=top;top=p;
; top->next=p;p=top;
; top=top->next;p=top;"
"题目 23:头指针为 head 的带头结点的单向链表为空的判定条件是( )为真。
: head->next!=NULL
; head->next==NULL
; head==NULL
; head->next!=NULL"
"题目 24:设有一个对称矩阵 A,采用压缩存储的方式,将其下三角部分以行序为主序存
储到一维数组 B 中(数组下标从 1 开始),B 数组共有 55 个元素,则该矩阵是( )阶
的对称矩阵。
: 5
; 15
; 20
; 10"
"题目 25:数组 a 经初始化 char a[ ]=“English”;a[1]中存放的是( )。
: "E"
; "n"
; 字符 n
; 字符 E"
"题目 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 个元素。
"题目 42:以下函数为链栈的进栈操作,x 是要进栈的结点的数据域,top 为栈顶指针
struct node
{ ElemType data;
struct node *next;
};
struct node *top ;
void Push(ElemType x)
{
struct node *p;
p=(struct node*)malloc [[1]];
p->data=x;
[[3]];
[[2]];
}
; [[1]] -> {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 [[3]];
p->data=x;
p->next=NULL;
[[1]];
rear= [[2]];
}
; [[1]] -> {rear->next=p / p / (sizeof (struct node)}"
电大数据结构(本)形考作业 3-阶段性学习测验 3 答案
"题目 1:假定一棵二叉树中,双分支结点数为 15,单分支结点数为 30,则叶子结点数为
( )。
: 16
; 15
; 17
; 47"
"题目 2:二叉树第 k 层上最多有( )个结点。
: 2k-1
; 2k
; 2k-1
; 2k-1"
"题目 3:将含有 150 个结点的完全二叉树从根这一层开始,每一层从左到右依次对结点进
行编号,根结点的编号为 1,则编号为 69 的结点的双亲结点的编号为( )。
: 33
; 34
; 35
; 36"
"题目 4:如果将给定的一组数据作为叶子数值,所构造出的二叉树的带权路径长度最小,
则该树称为( )。
: 二叉树
; 平衡二叉树
; 哈夫曼树
; 完全二叉树"
"题目 5:在一棵度具有 5 层的满二叉树中结点总数为( )。
: 33
; 32
; 16
; 31"
"题目 6:一棵完全二叉树共有 6 层,且第 6 层上有 6 个结点,该树共有( )个结点。
: 38
; 37
; 72
; 31"
"题目 7:利用 3、6、8、12 这四个值作为叶子结点的权,生成一棵哈夫曼树,该树中所有
叶子结点中的最长带权路径长度为( )。
: 18
; 16
; 30
; 12"
"题目 8:在一棵树中,( )没有前驱结点。
: 空结点
; 树根结点
; 叶结点
; 分支结点"
"题目 9:设一棵采用链式存储的二叉树,除叶结点外每个结点度数都为 2,该树结点中共
有 20 个指针域为空,则该树有( )个叶结点。
: 21
; 22
; 10
; 9"
"题目 10:在一个图 G 中,所有顶点的度数之和等于所有边数之和的( )倍。
: 2
; 4
; 1
; 1/2"
"题目 11:邻接表是图的一种( )。
: 链式存储结构
; 索引存储结构
; 顺序存储结构
; 散列存储结构"
"题目 12:图的深度优先遍历算法类似于二叉树的( )遍历。
: 后序
; 先序
; 层次
; 中序"
"题目 13:已知下图所示的一个图,若从顶点 V1 出发,按深度优先搜索法进行遍历,则可
能得到的一种顶点序列为( )。
: V1V2V4V8V3V5V6V7
; V1V3V6V7V2V4V5V8
; V1V2V4V5V8V3V6V7
; V1V2V4V8V5V3V6V7"
"题目 14:已知如下图所示的一个图,若从顶点 a 出发,按广度优先搜索法进行遍历,则
可能得到的一种顶点序列为( )。
: aedfcb
; aebcfd
; abecdf
; aecbdf"
"题目 15:图状结构中数据元素的位置之间存在( )的关系。
: 多对多
; 一对一
; 一对多
; 每一个元素都有一个且只有一个直接前驱和一个直接后继"
"题目 16:在一棵二叉树中,若编号为 i 的结点存在右孩子,则右孩子的顺序编号为
( )。
: 2i
; 2i+2
; 2i+1
; 2i-1"
"题目 17:一棵具有 16 个结点的完全二叉树,共有( )层。(设根结点在第一层)
: 4
; 5
; 6
; 7"
"题目 18:对二叉排序树进行( )遍历,可以使遍历所得到的序列是有序序列。
: 后序
; 按层次
; 中序
; 前序"
"题目 19:已知一个图的边数为 m,则该图的所有顶点的度数之和为( )。
: 2m
; m/2
; m
; 2m+1"
题目 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 个结点。
"题目 30: 以下程序是后序遍历二叉树的递归算法的程序,完成程序中空格部分
(树结构中左、右指针域分别为 left 和 right,数据域 data 为字符型,BT 指向根结点)。
完成程序中空格部分。
void
Inorder (struct BTreeNode *BT)
{
if( BT!=NULL)
{
Inorder(BT->left);
[[1]]
[[3]]
}
利用上述程序对左图进行后序遍历,结果是[[2]];
; [[1]] -> {Inorder(BT-> right ) / d,e,b,f,c,a / printf(“%c”,BT->data)}"
"题目 31: 以下程序是中序遍历二叉树的递归算法的程序,完成程序中空格部分
(树结构中左、右指针域分别为 left 和 right,数据域 data 为字符型,BT 指向根结点)。
void Inorder (struct BTreeNode *BT)
{
if(BT!=NULL){
Inorder(BT->left);}
[[2]];
[[3]];
}
利用上述程序对右图进行中序遍历,结果是[[1]];
; [[1]] -> {d,b,e,a,f,c / printf(“%c”,BT->data) / Inorder(BT->right)}"
"题目 32:(1)以 3,4,5,8,9,作为叶结点的权,构造一棵哈夫曼树。该树的带权路
径长度为 {A; B; C; D}.
A,64 B.65 C. 62 D. 66
(2)权重为 3 的叶结点的哈夫曼编码为{A; B; C; D}。
A.010 B.0101 C.000 D.0111"
"题目 33:(1)以 2,3,4,7,8,9 作为叶结点的权,构造一棵哈夫曼树,该树的带权
路径长度为{A; B; C; D}
A,66 B. 80 C. 62 D. 87
(2)权重值为 4 的叶结点的哈夫曼编码为{A; B; C; D}。
A.0001 B. 1110 C.001 D. 110"
"题目 34:(1)已知某二叉树的后序遍历序列是 debca,中序遍历序列是 dbeac,该二叉
树的根结点是{A; B; C; D}
A. e B. c C. b D. a
(2)先序遍历序列是{A; B; C; D}。
A. e,b,c,d,a B. c,a,b,,d,e C.
a,b,d,e,c D. a.c,b,d,e,"
"题目 35:(1)已知某二叉树的先序遍历序列是 aecdb,中序遍历序列是 eadcb,该二叉
树的根结点是{A; B; C; D};
A. e B. c C. b D. a
(2)后序遍历序列为{A; B; C; D}。
A. e,d,b,c,a B. c,a,b,,d,e C. a,b,d,e,c D.
a.c,b,d,e,"
"题目 36:(1)以给定权重值 5,6,17,18,25,30,为叶结点,建立一棵哈夫曼树,该
树的中序遍历序列为{A; B; C; D}
A. 5,11,28,6,17,58,30,101,18,43,25
B. 5,11,6,28,17,58,30,101,18,43,25
C. 5,11,6,28,101,58,30,17,18,43,25
D. 5,11,6,28,17,58,30,101,18,25,43
(2)权重值为 6 的叶结点的哈夫曼为{A; B; C; D}.
A. 1001 B. 011 C.001 D.0001"
电大数据结构(本)形考作业 4-阶段性学习测验 4 答案
: 以链接存储方式
; 以链接存储方式,且数据元素有序
; 以顺序存储方式,且数据元素有序
; 以顺序存储方式"
"题目 2:采用顺序查找方法查找长度为 n 的线性表时,每个元素的平均查找长度为
( )。
: (n-1)/2
; (n+1)/2
; n/2
; n"
"题目 3:有一个长度为 10 的有序表,按折半查找对该表进行查找,在等概率情况下查找
成功的平均比较次数为( )。
: 29/10
; 26/10
; 31/10
; 29/9"
"题目 4:已知一个有序表为{11,22,33,44,55,66,77,88,99},则顺序查找元素 55 需要比
较( )次。
: 5
; 6
; 4
; 3"
"题目 5:有数据{53,30,37,12,45,24,96},从空二叉树开始逐个插入数据来形成二叉排序
树,若希望高度最小,应该选择的序列是( )。
: 30,24,12,37,45,96,53
; 45,24,53,12,37,96,30
; 12,24,30,37,45,53,96
; 37,24,12,30,53,45,96"
"题目 6: 对于顺序存储的有序表{5,12,20,26,37,42,46,50,64},若采用折半查找,则查
找元素 26 的比较次数是( )。
: 6
; 4
; 5
; 3"
"题目 7:在所有的排序方法中,关键字比较的次数与记录初始排列秩序雅关的是
( )。
: 直接选择排序
; 希尔排序
; 冒泡排序
; 直接插入排序"
"题目 8:从未排序序列中依次取出元素与已经排好序的序列中的元素作比较。将其放入已
排序序列的正确的位置上,此方法称为( )。
: 选择排序
; 插入排序
; 交换排序
; 归并排序"
"题目 9:依次将每两个相邻的有序表合并成一个有序表的排序方法称为( )。
: 选择排序
; 交换排序
; 插入排序
; 归并排序"
"题目 10:当两个元素出现逆序的时候就交换位置,这种排序方法称为( )。
: 交换排序
; 选择排序
; 归并排序
; 插入排序"
"题目 11:每次把待排序的区间划分为左、右两个子区间,其中左区间中记录的关键字均
小于等于基准记录的关键字,右区间中记录的关键字均大于等于基准记录的关键字,这种
排序称为( )。
: 归并排序
; 快速排序
; 插入排序
; 堆排序"
"题目 12: 一组记录的关键字序列为(46,20,30,79,56,38,40,84,90,110),利用快
速排序,以第一个关键字为分割元素,经过一次划分后结果为( )。
: 20,30,40,38,46,79,56,84,90,100
; 30,20,40,38,46,84,56,79,90,100
; 40,20,30,38,46,56,79,84,90,110
; 20,30 38,40,46,56,79,84,90,100"
"题目 13:在有序表{10,14,34,43,47,64,75,80,90}中,用折半查找法查找值 80
时,经( )次比较后查找成功。
: 3
; 5
; 4
; 2"
"题目 14:对序列(49,38,65,97,76,13,47,50)采用直接插入排序法进行排序,
要把第七个元素 47 插入到已排序中,为寻找插入的合适位置需要进行( )次元素间
的比较。
: 5
; 6
; 4
; 3"
"题目 15:排序方法中,从未排序序列中挑选元素,并将其依次放入已排序序列(初始为
空)的一端的方法,称为( )排序。
: 插入
; 归并
; 快速
; 选择"
"题目 16:一组记录的关键字序列为(26,59,36,18,20,25),利用堆排序的方法建
立的初始小根堆为( )。
: 18,20,36,59,26,25
; 18,20,25,59,26,36
; 26,18,59,20,36,25
; 26,59,36,18,20,25"
"题目 17:一组记录的关键字序列为(25,48,16,35,79,82,23,40,36,72),其
中,含有 5 个长度为 2 的有序表,按归并排序的方法对该序列进行一趟归并后的结果为
( )。
: 16,25,35,48,23,40,79,82,36,72
; 16,25,35,48,79,82,23,36,40,72
; 16,25,48,35,79,82,23,36,40,72
; 16,25,35,48,79,23,36,40,82,72"
"题目 18:已知 10 个数据元素为(54,28,16,34,73,62,95,60,26,43),对该数
列从小到大排序,经过一趟冒泡排序后的序列为( )。
: 28,16,34,54,62,73,60,26,43,95
; 16,28,34,54,73,62,60,26,43,95
; 16,28,34,54,62,60,73,26,43,95
; 28,16,34,54,62,60,73,26,43,95"
"题目 19:一组记录的关键字序列为(46,79,56,38,40,84),利用快速排序,以第
一个关键字为分割元素,经过一次划分后结果为( )。
: 40,38,46,79,56,84
; 40,38,46,56,79,84
; 40,38,46,84,56,79
; 38,40,46,56,79,84"
"题目 20:一组记录的关键字序列为(80,57,41,39,46,47),利用堆排序(堆顶元素是最
小元素)的方法建立的初始堆为( )。
: 39,46,41,57,80,47
; 39,47,46,80,41,57
; 39,80,46,47,41,57
; 41,39,46,47,57,80"
"题目 21: 以下函数是二叉排序树的查找算法,若二叉树为空,则返回根结点的指
针,否则,返回值是指向树结点的结构指针 p(查找成功 p 指向查到的树结点,不成功 p
指向为 NULL)完成程序中的空格
typedef struct Bnode
{ int key;
struct Bnode *left;
struct Bnode *right;
} Bnode;
Bnode *BSearch(Bnode *bt, int k)
/* bt 用于接收二叉排序树的根结点的指针,k 用以接收要查找的关键字*/
{ Bnode *p;
if(bt== [[2]])
return (bt);
p=bt;
while(p->key!= [[5]])
{ if(kkey)
[[1]];
else [[3]];
if(p==NULL) break;
}
return([[4]];
}
; [[1]] -> {p=p->left / NULL / p=p->right / p / k}"
"题目 22: 以下程序是折半插入排序的算法
void binsort (NODE a[ ],int n)
{ int x,i,j,s,k,m;
for (i=2;i<=[[4]];i++)
s=1;
j=i-1;
while (s<=j)
{ m=[[1]]
if( x<a[m].key) [[2]] else
[[5]] } for
( k=i-1;k>=j+1;k- -)
[[3]]=a[k];
a[j+1]=a[0];
}
}
; [[1]] -> {(s+j)/2 / j=m-1 / a[k+1] / n / s=m+1}"
"题目 23: (1)设查找表为(1,10,11,14,23,27,29,55,68) ,画出对上述查找表进
行折半查找所对应的判定树,为了成功查找到元素 14,需要依次与元素{A; B; C; D}进行
比较。
A. 23,10,1,14 B.23,29,27,14 C.
23,10,11,14 D.23,29,55,14
(2)在等概率条件下,成功查找的平均比较次数为{A; B; C; D}。
A.24/9 B. 25
/9 C.3 D.2.5
"
"题目 24: (1)一组记录的关键字序列为(47,80,57,39,41,46),利用堆排
序的方法建立的初始堆为{A; B; C; D}(堆顶元素是最小元素,采用树的形式建堆)。
A. 39,41,57,80,47,46 B.39,41,46,80,47,57
C. 39,47,46,80,41,57 D.39,41,57,80,46,47
(2)输出堆顶元素后,调整后的堆为{A; B; C; D}。
A.41,47,46,80,57 B.41,57,46,80,47
C.41,57,80,47,46 D.41,80,46,47,57 "
"题目 25: (1)对关键字序列(56,51,71,54,46,106),利用快速排序,以第一个关键
字为分割元素,经过一次划分后结果为{A; B; C; D};
A. 46,51,56,54,71,106 B. 56,51,54,46,71,106
C. 46,51,54,56,71,106 D. 56,51,46,54,71,106
(2)一组记录的关键字序列为( 60,47,80,57, 39,41,46,30),利用归并排序的
方法,经过(2,2)归并的结果序列为{A; B; C; D}。.
A.(30, 57, 60, 80,47,39,41,46 ) B. (47, 60, 57, 80,
30,39,41,46 )
C.(41, 57, 60, 80, 30,39,47,46 ) D. (47, 57, 60, 80,
30,39,41,46 )"
"题目 26: (1)对关键字序列(36,69,46,28,30,74)采用快速排序,以第一个关键
字为分割元素,经过一次划分后的结果序列为{A; B; C; D}
A.30,28,46,36,69,74 B.28,30,36,46,69,74
C. 28,30,46,36,69,74 D. 30,28,36,46,69,74
(2)用冒泡法对上述序列排序,经两趟冒泡的结果序列为{A; B; C; D}。
A. 36,28,30,46,69,74 B. 36,46,28,20,69,74
.C. 38,36,30,46,69,74 D.28,36,,30,46,69,74"
"题目 27: (1)一组记录的关键字序列为{45,40,65,43,35,95}写出利用快速
排序的方法,以第一个记录为基准得到的一趟划分的结果为{A; B; C; D};
A. 35 40 65 45 35 95
B. 35 40 65 43 45 95
C. 35 40 43 45 65 95
D. 35 40 45 43 65 95
(2)对上述序列 利用直接插入排序,逐次插入过程中,共进行了{A; B; C; D}次元素间
的比较。
A. 8 B. 11 C.9 D.10"
来源 www.ybaotk.com |
|