“数据结构”期末考试试题
一、单选题(每小题2分,共12)
    1.在一个单链表HL中,若要向表头插入一个由指针p指向的结点,则执行( )
    A  HLps p>nextHL
    B  p>nextHLHLp3
    C  p>nextHlpHL
    D  p>nextHL>next;HL>nextp
    2n个顶点的强连通图中至少含有(    )
    A.n—l条有向边    B.n条有向边
    C.n(n—1)2条有向边    D.n(n1)条有向边
    3.从一棵二叉搜索树中查一个元素时,其时间复杂度大致为(    )
    A.O(1)    B.O(n)
C.O(1Ogzn)    D.O(n2)
4.由权值分别为38625的叶子结点生成一棵哈夫曼树,它的带权路径长度为(    )
    A24    B48
C  72    D  53
5.当一个作为实际传递的对象占用的存储空间较大并可能需要修改时,应最好把它说明为(    )参数,以节省参数值的传输时间和存储参数的空间。
    A.整形    B.引用型
    C.指针型    D.常值引用型·
6.向一个长度为n的顺序表中插人一个新元素的平均时间复杂度为(    )
    AO(n)    BO(1)
    CO(n2)    DO(10g2n)
二、填空题(每空1分,共28)
1.数据的存储结构被分为————————四种。
    2.在广义表的存储结构中,单元素结点与表元素结点有一个域对应不同,各自分别为——域和——域。
3——中缀表达式  3x*(2.45—6)所对应的后缀表达式为————
4.在一棵高度为h3叉树中,最多含有——结点。
5.假定一棵二叉树的结点数为18,则它的最小深度为——,最大深度为——·
    6.在一棵二叉搜索树中,每个分支结点的左子树上所有结点的值一定——该结点的值,右子树上所有结点的值一定——该结点的值。
    7.当向一个小根堆插入一个具有最小值的元素时,该元素需要逐层——调整,直到被调整到——位置为止。
8.表示图的三种存储结构为———————
    9.对用邻接矩阵表示的具有n个顶点和e条边的图进行任一种遍历时,其时间复杂度为——,对用邻接表表示的图进行任一种遍历时,其时间复杂度为——
  10.从有序表(1218304356788295)中依次二分查4356元素时,其查长度分别为————·
    11.假定对长度n144的线性表进行索引顺序查,并假定每个子表的长度均为,则进行索引顺序查的平均查长度为——,时间复杂度为——·
    12.一棵B—树中的所有叶子结点均处在——上。
    13.每次从无序表中顺序取出一个元素,把这插入到有序表中的适当位置,此种排序方法叫做——排序;每次从无序表中挑选出一个最小或最大元素,把它交换到有序表的一端,此种排序方法叫做——排序。
14.快速排序在乎均情况下的时间复杂度为——,最坏情况下的时间复杂度为——   
  三、运算题(每小题6分,共24)
    1.假定一棵二叉树广义表表示为a(b(cd)c(((8)))c语言中struct,分别写出对它进行先序、中序、后序和后序遍历的结果。
    先序:
    中序;
    后序:
    2.已知一个带权图的顶点集V和边集G分别为:
    V{012345}
    E={(01)8(02)5(03)2(15)6(23)25(24)13(35)9(45)10}
    则求出该图的最小生成树的权。
    最小生成树的权;
    3.假定一组记录的排序码为(4679563840845042),则利用堆排序方法建立的初始堆为——
    4.有7个带权结点,其权值分别为378261014,试以它们为叶子结点生成一棵哈夫曼树,求出该树的带权路径长度、高度、双分支结点数。
    带权路径长度:——  高度:——  双分支结点数:——
四、阅读算法,回答问题(每小题8分,共16)
    1VOldAC(List&L)
    {
    InitList(L)
    InsertRear(L;25)
    InsertFront(L50)
    IntaL4]{58121536};
    for(inti0; i<5; i++)
    if (a[i]2==0)InsertFront(La[i])
    elselnsertRear(La[i])
    }
    该算法被调用执行后,得到的线性表L为:
    2void AG(Queue&Q)
    {
    InitQueue(Q)
    inta[5]{6125158}
    for(int i0;i<5; i++)QInsert(Qa[i])
    QInsert(QQDelete(Q))
    QInsert(Q20)
    QInsert(QQDelete(Q)16)
    while(!QueueEmpty(Q))cout<<QDelete(Q)<<”;
    }
    该算法被调用后得到的输出结果为:
五、算法填空,在画有横线的地方填写合适的内容(每小题6分,共12)
    1.从一维数组A[n)中二分查关键字为K的元素的递归算法,若查成功则返回对应元素的下标,否则返回一1
    IntBinsch(ElemTypeA[]Intlowint highKeyTypeK)
    {
    if(low<high)
    {
    int mid(low+high)2
    if(K==A[mid].key)——
    else if (K<A[mid].key)——
    else   
    }
    else return—l
    }
    2.已知二叉树中的结点类型BinTreeNode定义为:
    structBinTreeNode{ElemType dataBinTreeNode*left*right}
    其中data为结点值域,leftright分别为指向左、右子女结点的指针域。下面函数的功能是返回二叉树BT中值为x的结点所在的层号,请在划有横线的地方填写合适内容。
    Int NodeLevel(BinTreeNode * BTElemType X)
    {
    if(BT:=NULL)return 0    //空树的层号为0
    else if(BT>data==X)return 1;  //根结点的层号为1
    //向子树中查x结点
    else{
    int clNodeLevel(BT>leftX)
    if(cl>1)return cl+1;
  int c2   
    if——
    //若树中不存在X结点则返回o
    else return 0
    }
    }
六、编写算法(8)
    按所给函数声明编写一个算法,从表头指针为HL的单链表中查出具有最大值的结点,该最大值由函数返回,若单链表为空则中止运行。
    EIemType MaxValue(LNOde*HL);
 
 
“数据结构”期末考试试题答案
  一、单选题(每小题2分,共12)
    评分标准;选对者得2分,否则不得分。
    1B    2B    3C    4D    5B    6A
  二、填空题(每空1分,共28)
    1.顺序结构    链接结构    索引结构    散列结构(次序无先后)

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。