实验一
算法分析的两个主要方面是时间复杂度和空间复杂度的分析。
抽象数据类型中基本的定义与具体的实现有关。×
算法可以没有输入,但是必须有输出。
一个完整的算法应该具有( 可行性、确定性和有穷性)等特性。
数据的(逻辑结构)包括集合、线性结构、树形结构和图形结构四种基本类型。
(集合)中任何两个结点之间都没有逻辑关系。
数据结构是一门研究非数值计算的程序设计问题中计算机的(操作对象)以及它们之间的关系和运算等的学科。
数据结构形式地定义为(K,R),其中K是(数据元素)的有限集合,R是K上的关系上的有限集合。
在数据结构中,与所使用的计算机无关的数据结构是(逻辑结构)。
线性结构中元素之间存在(一对一)关系。
图形结构中元素之间存在(一对多)关系。
实验二
可以使几个不同类型的变量共用同一段存储单元
当函数的返回值是数组类型的,传递的是数组第一个元素的地址
链表中逻辑上相邻的元素,其物理位置也一定相邻。 ×
指针p指向结点定义为(data,pre,next)的双向链表中的一个结点,则p->pre->next==p->next->pre。
数据结构涉及数据的逻辑结构、存储结构和施加其上的操作3个方面
被计算机加工的数据元素不是孤立的,它们彼此之间一般存在某种关系,通常把数据元素之间的这种关系称为(结构)
与单链表相比,双链表的优点之一是(顺序访问相邻结点更加灵活)。
将长度为n的单链表链接在长度为m的单链表之后的算法的时间复杂度为 O(m)
设有两个长度为n的单链表,结点类型相同。若以h1为表头指针的链表是非循环的,以h2为表头指针的链表是循环的,则()。
A.对于两个链表来说,删除第一个结点的操作,其时间复杂度都是O(1)
B.对于两个链表来说,删除最后一个结点的操作,其时间复杂度都是O(n)
C.循环链表要比非循环链表占用更多的内存空间
D.h1和h2是不同类型的变量
单链表又称为线性链表,在单链表上实施插入和删除操作( 不需移动结点,只需改变结点指针)。
单链表中,增加一个头结点的目的是(方便运算的实现)
链表要求内存中可用存储单元的地址(连续或不连续都可以)
双链表 - 删除结点
在双链表中,删除 s 所指结点,其语句应该为 :s->next->prev = s->prev; s->prev->next = s->next;
线性表在(线性表需经常插入或删除数据元素)情况下适合采用链式存储结构。
若单链表L(无头结点)则如何求出链表长度len:
int len=0;
while(L)
{
L=L->next;
len++;
}
以下关于递归调用的说法正确的是( )。
A.函数间接调用自己不是递归
B.递归调用可以用队列实现
C.递归调用可以用栈实现
D.函数直接调用自己是递归
实验三
(neuDS)顺序存储的线性表