数据结构基础复习(pta)

本文详细讨论了算法分析中的时间复杂度和空间复杂度,介绍了数据结构中的基本概念如抽象数据类型、逻辑结构(集合、线性、树形和图形)、数据元素、操作对象、链表(单链表、双向链表)以及各种数据结构的特点。同时涵盖了顺序存储、循环队列、二叉树、堆排序和递归等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实验一

算法分析的两个主要方面是时间复杂度和空间复杂度的分析。 

抽象数据类型中基本的定义与具体的实现有关。×

算法可以没有输入,但是必须有输出。

一个完整的算法应该具有( 可行性、确定性和有穷性)等特性。

数据的(逻辑结构)包括集合、线性结构、树形结构和图形结构四种基本类型。

(集合)中任何两个结点之间都没有逻辑关系。

数据结构是一门研究非数值计算的程序设计问题中计算机的(操作对象)以及它们之间的关系和运算等的学科。

数据结构形式地定义为(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)顺序存储的线性表

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值