欢迎来到天天文库
浏览记录
ID:38828322
大小:108.15 KB
页数:12页
时间:2019-06-20
《《数据结构(c语言版)》知识点概括》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、数据结构知识点概括O(n)、线性对数阶O(nlog2n)、平方阶O(n^2)、立方阶O(n^3)、,,k次方阶O(n^k)、指数阶O(2^n)。第一章概论空间复杂度:是某个算法的空间耗费,它是该算法所求解问题规模n的函数。数据就是指能够被计算机识别、存储和加工处理的信息的载体。算法的时间复杂度和空间复杂度合称算法复杂度。数据元素是数据的基本单位,可以由若干个数据项组成。数据项是具有独立含义的最小标识单位。第二章线性表数据结构的定义:线性表是由n≥0个数据元素组成的有限序列。·逻辑结构:从逻辑结构上描述数据,独立于计算机。·线性结构:一对一关系。n=0是空表;非空表,只能有一个开始结点,
2、有且只能有一个终端结点。·线性结构:多对多关系。线性表上定义的基本运算:·存储结构:是逻辑结构用计算机语言的实现。·顺序存储结构:如数组。·构造空表:Initlist(L)·链式存储结构:如链表。·求表长:Listlength(L)·索引存储结构:·稠密索引:每个结点都有索引项。·取结点:GetNode(L,i)·稀疏索引:每组结点都有索引项。·查找:LocateNode(L,x)·散列存储结构:如散列表。·插入:InsertList(L,x,i)·数据运算。·删除:Delete(L,i)·对数据的操作。定义在逻辑结构上,每种逻辑结构都有一个运算集合。顺序表是按线性表的逻辑结构次序依次
3、存放在一组地址连续的存储单元中。在存储·常用的有:检索、插入、删除、更新、排序。单元中的各元素的物理位置和数据类型:是一个值的集合以及在这些值上定义的一组操作的总称。逻辑结构中各结点相邻关系是一致的。地址计算:LOCa(i)=LOCa(1)+(i-1)*d;·结构类型:由用户借助于描述机制定义,是导出类型。(首地址为1)抽象数据类型ADT:·是抽象数据的组织和与之的操作。相当于在概念层上描述问在顺序表中实现的基本运算:题。·插入:平均移动结点次数为n/2;平均时间复杂度均为O(n)。·优点是将数据和操作封装在一起实现了信息隐藏。·删除:平均移动结点次数为(n-1)/2;平均时间复杂度均
4、为O(n)。程序设计的实质是对实际问题选择一种好的数据结构,设计一个好的算法。算法取决于线性表的链式存储结构中结点的逻辑次序和物理次序不一定相同,为了能正确表示数据结构。结点间的逻辑关系,在存储每个结点值的同时,还存储了其后继结点的地址信息(即指算法是一个良定义的计算过程,以一个或多个值输入,并以一个或多个值输出。针或链)。这两部分信息组成链表中的结点结构。评价算法的好坏的因素:·算法是正确的;一个单链表由头指针的名字来命名。·执行算法的时间;单链表运算:·执行算法的存储空间(主要是辅助存储空间);·建立单链表·头插法:s->next=head;head=s;生成的顺序与输入顺序相反。
5、平均时·算法易于理解、编码、调试。间复杂度均为O(n)。时间复杂度:是某个算法的时间耗费,它是该算法所求解问题规模n的函数。·尾插法:head=rear=null;if(head=null)head=s;elser->next=s;r=s;平均时间复渐近时间复杂度:是指当问题规模趋向无穷大时,该算法时间复杂度的数量级。杂度均为O(n)评价一个算法的时间性能时,主要标准就是算法的渐近时间复杂度。·加头结点的算法:对开始结点的操作无需特殊处理,统一了空表和非空表。算法中语句的频度不仅与问题规模有关,还与输入实例中各元素的取值相关。·查找·按序号:与查找位置有关,平均时间复杂度均为O(n)。
6、时间复杂度按数量级递增排列依次为:常数阶O(1)、对数阶O(log2n)、线性阶·按值:与输入实例有关,平均时间复杂度均为O(n)。·插入运算:p=GetNode(L,i-1);s->next=p->next;p->next=s;平均时间复杂度出错状态。均为O(n)·“下溢”可以表示栈为空栈,因此用来作为控制转移的条件。·删除运算:p=GetNode(L,i-1);r=p->next;p->next=r->next;free(r);平均时间复顺序栈中的基本操作有六种:·构造空栈·判栈空·判栈满·进栈·退栈·取杂度均为O(n)栈顶元素单循环链表是一种首尾相接的单链表,终端结点的指针域指向
7、开始结点或头结点。链表链栈则没有上溢的限制,因此进栈不要判栈满。链栈不需要在头部附加头结点,只终止条件是以指针等于头指针或尾指针。要有链表的头指针就可以了。采用单循环链表在实用中多采用尾指针表示单循环链表。优点是查找头指针和尾指链栈中的基本操作有五种:·构造空栈·判栈空·进栈·退栈·取栈顶元素针的时间都是O(1),不用队列(Queue)是一种运算受限的线性表,插入在表的一端进行,而删除在表的另一端遍历整个链表。进行,允许删除的一端称双链表就是双
此文档下载收益归作者所有