首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读下列说明和C代码,回答问题1至问题3,将解答写在答题纸的对应栏内。 【说明】 堆数据结构定义如下: 对于n个元素的关键字序列{a1,a2,…,an},当且仅当满足下列关系时称其为堆。 在一个堆中,若堆顶元素为最大元素,则称为大顶堆;若堆顶元素
阅读下列说明和C代码,回答问题1至问题3,将解答写在答题纸的对应栏内。 【说明】 堆数据结构定义如下: 对于n个元素的关键字序列{a1,a2,…,an},当且仅当满足下列关系时称其为堆。 在一个堆中,若堆顶元素为最大元素,则称为大顶堆;若堆顶元素
admin
2011-04-06
71
问题
阅读下列说明和C代码,回答问题1至问题3,将解答写在答题纸的对应栏内。
【说明】
堆数据结构定义如下:
对于n个元素的关键字序列{a1,a2,…,an},当且仅当满足下列关系时称其为堆。
在一个堆中,若堆顶元素为最大元素,则称为大顶堆;若堆顶元素为最小元素,则称为小顶堆。堆常用完全二叉树表示,图4—1是一个大顶堆的例子。
堆数据结构常用于优先队列中,以维护由一组元素构成的集合。对应于两类堆结构,优先队列也有最大优先队列和最小优先队列,其中最大优先队列采用大顶堆,最小优先队列采用小顶堆。以下考虑最大优先队列。
假设现已建好大顶堆A,且已经实现了调整堆的函数heapify(A,n,index)。
下面将C代码中需要完善的三个函数说明如下:
(1)heapMaximum(A):返回大顶堆A中的最大元素。
(2)heapExtractMax(A):去掉并返回大顶堆A的最大元素,将最后一个元素“提前”到堆顶位置,并将剩余元素调整成大顶堆。
(3)maxHeaplnseit(A,key):把元素key插入到大顶堆A的最后位置,再将A调整成大顶堆。
优先队列采用顺序存储方式,其存储结构定义如下:
#define PARENT(i)i/2
typedef struct array{
int *int_array;//优先队列的存储空间首地址
int array_size;能//优先队列的长度
int capacity;//优先队列存储空间的容量
}ARRAY;
【c代码】
(1)函数heapMaximum
int heapMaximum(ARRAY*A){return (1);}
(2)函数heapExtractMax
int heapExtractMax(ARRAY*A){
int max;
max=A->int_array[0];
(2);
A->array_size --;
heapify(A,A->array_size,0);//将剩余元素调整成大顶堆
return max;
}
(3)函数maxHeaplnsert
int maxHeaplnsert(ARRAY*A,int key){
int i*P;
if(A->array-size==A->capacity){//存储空间的容量不够时扩充空间
P=(int*)realloc(A->int_array,A->capacity*2*sizeof(int));
if(!P)return-1;
A->int_array=P:
A->capacity=2*A->capacity;
}
A->array_size++;
i=(3);
while(i>0&&(4)){
A->int_array
=A->int_array[PARENT(i)];
i=PARENT(i);
}
(5)
return 0;
}
若将元素10插入到堆A=(15,13,9,5,12,8,7,4,0,6,2,1)中,调用maxHeaplnsert函数进行操作,则新插入的元素在堆A中第(9)个位置(从1开始)。
选项
答案
(9)3
解析
依照maxHeapInsert的算法,可有如下几步:
第一步:i=13 PARENT(i)=6 key=10 A->int_array [PARENT(i)]=8
由于key>A->int_array[PARENT(i)]
所以符合while循环条件,执行:
A->int_array
=A->int_array[PARENT(i)];
i=PARENT(i);
即:
第二步:i=6 PARENT(i)=3 key=10 A->int_array [PARENT (i)]=9
由于key>A->int_array[PARENT(i)]
所以符合while循环条件,执行:
A->int_array
=A->int_array[PARENT(i)];
i=PARENT(i);
即:
第三步:i=3 PARENT(i)=1 key=10 A->int_array [PARENT(i)]=15
由于key
int_array[PARENT(i)]
所以不符合while循环条件,跳出循环。
执行:A->int_array
=key;
即:
所以,插入元素10的位置在第三个位置。
转载请注明原文地址:https://kaotiyun.com/show/nlDZ777K
本试题收录于:
软件设计师下午应用技术考试题库软考中级分类
0
软件设计师下午应用技术考试
软考中级
相关试题推荐
软件开发中经常利用配置库实现变更控制,主要是控制软件配置项的状态变化,不受配置管理控制的是()。
下面关于防火墙功能的说法中,不正确的是(6)。
对于初始为空的栈S,入栈序列为a、b、c、d,且每个元素进栈、出栈各1次。若出栈序列的第一个元素为d,则合法的出栈序列为______。
下面关于软件测试的说法,(48)是错误的。
根据输出对输入的依赖关系设计测试用例的黑盒测试方法是________。
软件内部/外部质量模型中,以下(66)不是功能性包括的子特性。
以下关于测试方法的叙述中,不正确的是_______。
若计算机存储数据采用的是双符号位(00表示正号、11表示负号),两个符号相同的数相加时,如果运算结果的两个符号位经()运算得1,则可断定这两个数相加的结果产生了溢出。
下面为C语言程序,边界值问题可以定位在(45)。 int data(3), int i, for(i=1, i<=3, i++)data(i)=100
给出关系R(A,B,C)和S(A,B,C),R和S的函数依赖集F={A→B,B→C}。若R和S进行自然连接运算,则结果集有3个属性。关系R和S________。
随机试题
关于角膜屈光的描述,正确的是
属于肾小管性蛋白尿的情况是()
下列各项,不属麻疹逆证病因的是
公路建设项目招投标活动中,中标者接到中标通知书后应在()天内与招标单位签订承包合同。
客户在理财过程中产生的义务性支出包括()。
下图为人体内三大营养物质代谢示意图,据图回答下列问题:(1)人体内氨基酸的来源可包括图中的①、④、⑤等过程:其中由①获得的氨基酸被称为( )。可通过( )作用形成。(2)图中过程②( )控制,直接以( )为模板。假设合成的蛋白质由270个氨基
简述幼儿教育心理学的研究任务。
衡量改革开放中一切工作是非得失的根本标准是()。
Nobody,itseems,wantstobeleftoutofArgentina’scurrentboomintelevisionrealityshows.Afterthesuccessoflocalversi
你得承认,多媒体不只是一件东西,而是包括许多东西的复杂的组合:硬件、软件和这两者相遇时的界面。不,我们还忘了一件很重要的事情。多媒体还包括你。是的,就是!对于多媒体,你不再是一个被动的观众,你可以控制,可以交互作用,可以让它按你的需要去做。这就意
最新回复
(
0
)