优先队列通常采用(62)数据结构实现,向优先队列中插入—个元素的时间复杂度为(63)。A.Θ(n)B.Θ(1)C.Θ(lgn)D.Θ(n2)

优先队列通常采用(62)数据结构实现,向优先队列中插入—个元素的时间复杂度为(63)。

A.Θ(n)
B.Θ(1)
C.Θ(lgn)
D.Θ(n2)

参考解析

解析:本题考查数据结构基础知识。普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除。在优先队列中,元素被赋予优先级。当访问元素时,具有最高优先级的元素最先删除。优先队列具有最高级先出(largest-in,first-out)的行为特征。优先队列一般采用二叉堆数据结构实现,由于是二叉堆,所以插入和删除一个元素的时间复杂度均为O(lgn)。本题依次选A、C选项。

相关考题:

● 栈和队列都是线性的数据结构。以下关于栈和队列的叙述中,正确的是 (37) 。(37)A. 栈适合采用数组存储,队列适合采用循环单链表存储B. 栈适合采用单链表存储,队列适合采用数组存储C. 栈和队列都不允许在元素序列的中间插入和删除元素D. 若进入栈的元素序列确定,则从栈中出来的序列也同时确定

队列的“先进先出”特性是指()。A.最早插入队列中的元素总是最后被删除B.当同时进行插入、删除操作时,总是插入操作优先C.每当有删除操作时,总是要先做一次插入操作D.每次从队列中删除的总是最早插入的元素

以下哪一个不是队的基本运算?( )A)从队列中删除第i个元素B)从队尾插入一个新元素C)将队列置为空队列D)读取队头元素的值

依次在初始队列为空的队列中插入元素a,b,c,d(设此设备最多容纳五个元素)。接着做了两次删除操作,此时,还可以向队列中插()个元素A2B1C0D3

对于长度为n的顺序表,插入或删除表中元素的时间复杂度为【 】 ;对于顺序栈或队列,插入或删除表中元素的时间复杂度为【 】。

以下关于栈和队列的叙述中,错误的是( )。A.栈和队列都是线性的数据结构 B.栈和队列都不允许在非端口位置插入和删除元素 C.一个序列经过一个初始为空的栈后,元素的排列次序一定不变 D.一个序列经过一个初始为空的队列后,元素的排列次序不变

试题四(共15分)阅读下列说明和C代码,回答问题1至问题 3,将解答写在答题纸的对应栏内。【说明】堆数据结构定义如下:在一个堆中,若堆顶元素为最大元素,则称为大顶堆;若堆顶元素为最小元素,则称为小顶堆。堆常用完全二叉树表示,图4-1 是一个大顶堆的例子。堆数据结构常用于优先队列中,以维护由一组元素构成的集合。对应于两类堆结构,优先队列也有最大优先队列和最小优先队列,其中最大优先队列采用大顶堆,最小优先队列采用小顶堆。以下考虑最大优先队列。假设现已建好大顶堆A,且已经实现了调整堆的函数heapify(A, n, index)。下面将C代码中需要完善的三个函数说明如下:(1)heapMaximum(A):返回大顶堆A中的最大元素。(2)heapExtractMax(A):去掉并返回大顶堆 A的最大元素,将最后一个元素“提前”到堆顶位置,并将剩余元素调整成大顶堆。(3)maxHeapInsert(A, key):把元素key插入到大顶堆 A的最后位置,再将 A调整成大顶堆。优先队列采用顺序存储方式,其存储结构定义如下:define PARENT(i) i/2typedef struct array{int *int_array; //优先队列的存储空间首地址int array_size; //优先队列的长度int capacity; //优先队列存储空间的容量} ARRAY;【C代码】(1)函数heapMaximumint heapMaximum(ARRAY *A){ return (1) ; }(2)函数heapExtractMaxint heapExtractMax(ARRAY *A){int max;max = A-int_array[0];(2) ;A-array_size --;heapify(A,A-array_size,0); //将剩余元素调整成大顶堆return max;}(3)函数maxHeapInsertint maxHeapInsert(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[i] = A-int_array[PARENT(i)];i = PARENT(i);}(5) ;return 0;}【问题 1】(10分)根据以上说明和C代码,填充C代码中的空(1)~(5)。【问题 2】(3分)根据以上C代码,函数heapMaximum、heapExtractMax和 maxHeapInsert的时间复杂度的紧致上界分别为 (6) 、 (7) 和 (8) (用O 符号表示)。【问题 3】(2分)若将元素10插入到堆A =〈15, 13, 9, 5, 12, 8, 7, 4, 0, 6, 2, 1〉中,调用 maxHeapInsert函数进行操作,则新插入的元素在堆A中第 (9) 个位置(从 1 开始)。

优先队列通常采用( )数据结构实现,向优先队列中插入—个元素的时间复杂度为(请作答此空)。A.Θ(n)B.Θ(1)C.Θ(lgn)D.Θ(n^2)

优先队列通常采用(62)数据结构实现,向优先队列中插入—个元素的时间复杂度为(63)。A.堆B.栈C.队列D.线性表

优先队列通常采用(请作答此空)数据结构实现,向优先队列中插入—个元素的时间复杂度为( )。A.堆B.栈C.队列D.线性表

优先队列可用()数据结构实现。

优先队列通常用()数据结构来实现。A、栈B、堆C、队列D、二叉查找树

优先队列通常用以下()数据结构来实现。A、栈B、堆C、队列D、二叉查找树

PQ队列分别为()。A、高优先队列B、中优先队列C、正常优先队列D、低优先队列

以下()不是队列的基本运算A、从队尾插入一个新元素B、从队列中删除第i个元素C、判断一个队列是否为空D、读取队头元素的值

向一个循环队列中插入元素时,需要首先移动(),然后再向所指位置()新插入的元素。

队列的“先进先出”特性是指()。A、最早插入队列中的元素总是最后被删除B、当同时进行插入、删除操作时,总是插入操作优先C、每当有删除操作时,总是要先做一次插入操作D、每次从队列中删除的总是最早插入的元素

QoS优先级排队使用哪优先级队列()A、高优先级队列B、中优先级队列C、普通优先级队列D、低优先级队列E、简化队列

使用优先级排队时,哪种优先级让消息得到一定的优先处理()A、高优先级队列B、中优先级队列C、普通优先级队列D、低优先级队列

在长度为n的队列中插入一个新元素的操作的时间复杂度为()

单选题使用优先级排队时,哪种优先级让消息得到一定的优先处理()A高优先级队列B中优先级队列C普通优先级队列D低优先级队列

多选题QoS优先级排队使用哪优先级队列()A高优先级队列B中优先级队列C普通优先级队列D低优先级队列E简化队列

单选题优先队列通常用()数据结构来实现。A栈B堆C队列D二叉查找树

单选题优先队列通常用以下()数据结构来实现。A栈B堆C队列D二叉查找树

填空题优先队列可用()数据结构实现。

多选题PQ队列分别为()。A高优先队列B中优先队列C正常优先队列D低优先队列

填空题在长度为n的队列中插入一个新元素的操作的时间复杂度为()