第3章 线性结构-数组-串
《数据结构》填空作业题(答案)
《数据结构》填空作业题答案第 1 章绪论(已校对无误)1.数据结构包括数据的逻辑结构、数据的存储结构和数据的运算三方面的内容。
2.程序包括两个内容:数据结构和算法。
3.数据结构的形式定义为:数据结构是一个二元组:Data Structure =( D, S)。
4.数据的逻辑结构在计算机存储器内的表示,称为数据的存储结构。
5.数据的逻辑结构可以分类为线性结构和非线性结构两大类。
6.在图状结构中,每个结点的前驱结点数和后继结点数可以有多个。
7.在树形结构中,数据元素之间存在一对多的关系。
8.数据的物理结构,指数据元素在计算机中的标识(映象),也即存储结构。
9.数据的逻辑结构包括线性结构、树形结构和图形结构 3 种类型,树型结构和有向图结构合称为非线性结构。
10. 顺序存储结构是把逻辑上相邻的结点存储在物理上连续的存储单元里,结点之间的逻辑关系由存储单元位置的邻接关系来体现。
11. 链式存储结构是把逻辑上相邻的结点存储在物理上任意的存储单元里,节点之间的逻辑关系由附加的指针域来体现。
12.数据的存储结构可用 4 种基本的存储方法表示,它们分别是顺序存储、链式存储、索引存储和散列存储。
13. 线性结构反映结点间的逻辑关系是一对一的,非线性结构反映结点间的逻辑关系是一对多或多对多。
14.数据结构在物理上可分为顺序存储结构和链式存储结构。
15. 我们把每种数据结构均视为抽象类型,它不但定义了数据的表示方式,还给出了处理数据的实现方法。
16.数据元素可由若干个数据项组成。
17.算法分析的两个主要方面是时间复杂度和空间复杂度。
18.一个算法的时间复杂度是用该算法所消耗的时间的多少来度量的,一个算法的空间复杂度是用该算法在运行过程中所占用的存储空间的大小来度量的。
19.算法具有如下特点:有穷性、确定性、可行性、输入、输出。
20. 对于某一类特定的问题,算法给出了解决问题的一系列操作,每一操作都有它的确切的定义,并在有穷时间内计算出结果。
数据结构第三章字符串
串
子串:串中任意个连续的字符组成的子序列。 主串:包含子串的串。 子串的位置:子串的第一个字符在主串中的序号。
S1="ab12cd " S2="ab12" S3="ab13" S4="ab12φ" S5=" " S6="φφφ "
串
串的比较:通过组成串的字符之间的比较来进行的。
给定两个串:X="x1x2…xn"和Y="y1y2…ym",则: 1. 当n=m且x1=y1,…,xn=ym时,称X=Y; 2. 当下列条件之一成立时,称X<Y: ⑴ n<m且xi=yi(1≤ i≤n); ⑵存在k≤min(m,n),使得xi=yi(1≤i≤k-1)且xk<yk。 例:S1="ab12cd ",S2="ab12",S3="ab13"
串
例:主串S="ababcabcacbab",模式T="abcac"
i
第 4 趟
a b a b c a b c a c b a b a b c a c
j
i=4,j=1失败 i回溯到5,j回溯到1
Hale Waihona Puke 串例:主串S="ababcabcacbab",模式T="abcac"
i
第 5 趟
a b a b c a b c a c b a b a b c a c
为什么BF算法时间性能低?
在每趟匹配不成功时存在大量回溯,没有利用已经 部分匹配的结果。
如何在匹配不成功时主串不回溯?
主串不回溯,模式就需要向右滑动一段距离。
数据结构(C语言版)_第3章 串与数组
char data; struct lnode *next;
}lstring;
3.3.3 串的存储结构——链式存储结构
当结点大小>1时,可以采用块链结构。
#define CHUNKSIZE 100
/*可由用户定义块的大小*/
typedef struct Chunk
第三章 串与数组
本章要点
➢字符串的基本概念与基本运算 ➢字符串的存储和基本运算的实现 ➢数组的概念和基本运算 ➢数组的存储结构 ➢特殊矩阵的压缩存储及运算 ➢广义表的概念及相关术语 ➢广义表的存储形式
3.1 “文学研究助手”案例导入
“文学研究助手”引例:请从下面的英文文章里,统计其中 good出现的次数和位置,并查找单词the所在的行号,该行中出 现的次数以及在该行中的相应位置。
3.4.1 数组的定义
数组是n个具有相同类型的数据元素构成的有限序列,数组 中的数据是按顺序存储在一块地址连续的存储单元中。
数组中的每一个数据通常称为数组元素,数组元素用下标 区分,其中下标的个数由数组的维数决定。
若线性表中的数据元素为非结构的简单元素,则称为一维 数组,又称为向量;若一维数组中的数据元素又是一维数组结 构,则称为二维数组;依次类推,若二维数组中的元素又是一 个一维数组结构,则称作三维数组。
3.3.4 串的基本操作的实现算法
第二种顺序存储方式下几种基本操作的算法
算法1:串连接操作 算法2:串比较操作 算法3:取子串操作 算法4:串插入操作 算法5:串删除操作 算法6:串置换函数 算法7:子串定位操作
3.3.5 串的应用
【例3-1】设计一个算法求串s中出现的第1个最长重复子串 及其位置。
第三章 特殊线性表
(6)撤消动态申请空间Destroy(*head)
void Destroy(LSNode *head) { LSNode *p, *p1;
p = head;
while(p != NULL)
{ p1 = p;
p = p->next;
free(p1); }
}
3.2 堆栈应用
1、括号匹配问题
例:假设一个算术表达式中包含圆括号、方括号和花括号三种类型的括号, 编写一个判别表达式中括号是否正确配对的函数,并设计一个测试主函数。 算法思想: 算术表达式中右括号和左括号匹配的次序正好符合后到的括号要最先 被匹配的“后进先出”堆栈操作特点,因此可以借助一个堆栈来进行判断。 括号匹配共有四种情况: (1)左右括号配对次序不正确;(2)右括号多于左括号; (3)左括号多于右括号; (4)左右括号匹配正确。 具体方法:顺序扫描算术表达式(表现为一个字符串),当遇到三种类型 的左括号时让该括号进栈;当扫描到某一种类型的右括号时,比较当前栈 顶括号是否与之匹配,若匹配则退栈继续进行判断;若当前栈顶括号与当 前扫描的括号不相同,则左右括号配对次序不正确;若字符串当前为某种 类型左括号而堆栈已空,则右括号多于左括号;字符串循环扫描结束时, 若堆栈非空(即堆栈中尚有某种类型左括号),则说明左括号多于右括号; 否则,左右括号匹配正确。
中缀表达式变换为后缀表达式的算法步骤可以总结 为: (1)设置一个堆栈,初始时将栈顶元素置为“#”。 (2)顺序读入中缀表达式,当读到的单词为操作数时 就将其输出,并接着读下一个单词。 (3)令x1为当前栈顶运算符的变量,x2为当前扫描读 到运算符的变量,当顺序从中缀表达式中读入的单词为 运算符时就赋予x2,然后比较x1的优先级与x2的优先级, 若x1的优先级高于x2的优先级,将x1退栈并作为后缀表 达式的一个单词输出,然后接着比较新的栈顶运算符x1 的优先级与x2的优先级。
数据结构详细笔记
第1章绪论◆基本概念:数据、数据元素、数据对象、数据结构、数据类型、抽象数据类型。
数据——所有能被计算机识别、存储和处理的符号的集合。
数据元素——是数据的基本单位,具有完整确定的实际意义。
数据对象——具有相同性质的数据元素的集合,是数据的一个子集。
数据结构——是相互之间存在一种或多种特定关系的数据元素的集合,表示为:Data_Structure=(D, R)数据类型——是一个值的集合和定义在该值上的一组操作的总称。
抽象数据类型——由用户定义的一个数学模型与定义在该模型上的一组操作,它由基本的数据类型构成。
◆算法算法:是指解题方案的准确而完整的描述。
算法不等于程序,也不等计算机方法,程序的编制不可能优于算法的设计。
算法的基本特征:是一组严谨地定义运算顺序的规则,每一个规则都是有效的,是明确的,此顺序将在有限的次数下终止。
特征包括:(1)可行性;(2)确定性,算法中每一步骤都必须有明确定义,不充许有模棱两可的解释,不允许有多义性;(3)有穷性,算法必须能在有限的时间内做完,即能在执行有限个步骤后终止,包括合理的执行时间的含义;(4)拥有足够的情报。
算法的基本要素:一是对数据对象的运算和操作;二是算法的控制结构。
指令系统:一个计算机系统能执行的所有指令的集合。
基本运算和操作包括:算术运算、逻辑运算、关系运算、数据传输。
算法的控制结构:顺序结构、选择结构、循环结构。
算法基本设计方法:列举法、归纳法、递推、递归、减斗递推技术、回溯法。
算法复杂度:算法时间复杂度和算法空间复杂度。
算法时间复杂度是指执行算法所需要的计算工作量。
算法空间复杂度是指执行这个算法所需要的内存空间。
for ( i = 1 , i < = 10 , i++ ) x=x+c; =>O(1)for ( i = 1 , i < = n , i++ ) x=x+n; =>O(n)多嵌套一个for,则为=>O(n^2) 以此类推真题难点:i = 1,while(i < = n)i = i * 3;=>O(log3^n)i = i * 2;=>O(log2^n) 以此类推数据的逻辑结构有以下两大类:线性结构:有且仅有一个开始结点和一个终端结点,且所有结点都最多只有一个直接前驱和一个直接后继。
数据结构(C++版)第3章 特殊线性表
特殊线性表——栈
3.1.3 栈的链接存储结构及实现
链栈:栈的链接存储结构 first
a1
a2
ai
an ∧
将哪一端作为栈顶? 将链头作为栈顶,方便操作。 链栈需要加头结点吗? 链栈不需要附设头结点。
特殊线性表——栈
栈的链接存储结构及实现
链栈:栈的链接存储结构 first top an
栈顶
a1
a2 a1 ∧
Pop( );
an
an-1
a1 ∧
特殊线性表——栈
顺序栈和链栈的比较
时间性能:相同,都是常数时间O(1)。
空间性能: 顺序栈:有元素个数的限制和空间浪费的问题。 链栈:没有栈满的问题,只有当内存没有可用空间时才会 出现栈满,但是每个元素都需要一个指针域,从而产生了 结构性开销。 结论:当栈的使用过程中元素个数变化较大时,用链栈是适 宜的,反之,应该采用顺序栈。
两栈共享空间
两栈共享空间
0 1 2 ……
S-1
a 1 a2 … ai
栈1底
bj … … b2 b 1
top2
栈2底
top1
栈1的底固定在下标为0的一端; 栈2的底固定在下标为StackSize-1的一端。 top1和top2分别为栈1和栈2的栈顶指针; Stack_Size为整个数组空间的大小(图中用S表示);
an
an-1
p
a1 ∧ top++可以吗?
特殊线性表——栈
链栈的实现——链栈的析构(链栈的销毁)
template <class T> LinkStack<T>::~LinkStack( ) {
Node<T> *p;
数据结构作业题及答案
数据结构作业题及答案第一章绪论1、简述下列概念:数据、数据元素、数据结构、逻辑结构、存储结构、线性结构、非线性结构。
数据:指能够被计算机识别、存储和加工处理的信息载体。
数据元素:就是数据的基本单位,在某些情况下,数据元素也称为元素、结点、顶点、记录。
数据元素有时可以由若干数据项组成。
数据结构:指的是数据之间的相互关系,即数据的组织形式。
一般包括三个方面的内容:数据的逻辑结构、存储结构和数据的运算。
逻辑结构:指各数据元素之间的逻辑关系。
存储结构:就是数据的逻辑结构用计算机语言的实现。
线性结构:数据逻辑结构中的一类,它的特征是若结构为非空集,则该结构有且只有一个开始结点和一个终端结点,并且所有结点都最多只有一个直接前趋和一个直接后继。
线性表就是一个典型的线性结构。
非线性结构:数据逻辑结构中的另一大类,它的逻辑特征是一个结点可能有多个直接前趋和直接后继。
2、常用的存储表示方法有哪几种?顺序存储方法:它是把逻辑上相邻的结点存储在物理位置相邻的存储单元里,结点间的逻辑关系由存储单元的邻接关系来体现。
由此得到的存储表示称为顺序存储结构。
链接存储方法:它不要求逻辑上相邻的结点在物理位置上亦相邻,结点间的逻辑关系是由附加的指针字段表示的。
由此得到的存储表示称为链式存储结构。
索引存储方法:除建立存储结点信息外,还建立附加的索引表来标识结点的地址。
散列存储方法:就是根据结点的关键字直接计算出该结点的存储地址。
3、求解下列算法的时间复杂度(1)i=1;k=0 while(i<n){k=k+10*i;i++;}T(n)=n-1∴T(n)=O(n)这个函数是按线性阶递增的(2)i=0;k=0;do{k=k+10*i;i++;} while(i<n);T(n)=n∴T(n)=O(n)这也是线性阶递增的(3)i=1;j=0;while(i+j<=n) {if(i<j)j++; else i++;}T(n)=n/2∴T(n)=O(n)虽然时间函数是n/2,但其数量级仍是按线性阶递增的。
《数据结构》填空作业题(答案)
《数据结构》填空作业题答案第1章绪论(已校对无误)1.数据结构包括数据的逻辑结构、数据的存储结构和数据的运算三方面的内容。
2.程序包括两个内容:数据结构和算法。
3. 数据结构的形式定义为:数据结构是一个二元组:Data Structure =(D,S)。
4. 数据的逻辑结构在计算机存储器内的表示,称为数据的存储结构。
5. 数据的逻辑结构可以分类为线性结构和非线性结构两大类。
6. 在图状结构中,每个结点的前驱结点数和后继结点数可以有多个。
7. 在树形结构中,数据元素之间存在一对多的关系。
8. 数据的物理结构,指数据元素在计算机中的标识(映象),也即存储结构。
9. 数据的逻辑结构包括线性结构、树形结构和图形结构3种类型,树型结构和有向图结构合称为非线性结构。
10. 顺序存储结构是把逻辑上相邻的结点存储在物理上连续的存储单元里,结点之间的逻辑关系由存储单元位置的邻接关系来体现。
11. 链式存储结构是把逻辑上相邻的结点存储在物理上任意的存储单元里,节点之间的逻辑关系由附加的指针域来体现。
12. 数据的存储结构可用4种基本的存储方法表示,它们分别是顺序存储、链式存储、索引存储和散列存储。
13. 线性结构反映结点间的逻辑关系是一对一的,非线性结构反映结点间的逻辑关系是一对多或多对多。
14. 数据结构在物理上可分为顺序存储结构和链式存储结构。
15. 我们把每种数据结构均视为抽象类型,它不但定义了数据的表示方式,还给出了处理数据的实现方法。
16. 数据元素可由若干个数据项组成。
17. 算法分析的两个主要方面是时间复杂度和空间复杂度。
18. 一个算法的时间复杂度是用该算法所消耗的时间的多少来度量的,一个算法的空间复杂度是用该算法在运行过程中所占用的存储空间的大小来度量的。
19. 算法具有如下特点:有穷性、确定性、可行性、输入、输出。
20. 对于某一类特定的问题,算法给出了解决问题的一系列操作,每一操作都有它的确切的定义,并在有穷时间内计算出结果。
数据结构电子教案
时数
讲课 4 6 4 实验 6 2
12 10 12 12 10 2 80
6 6 6 8 6 46
6 4 6 4 4 32
教学建议
1.教学手段,应采用先进的形象化教学手段 。 2.教学模式,采用实例(案例)教学法。 3.加强实践教学,除规定实验课时外,还应安排1~2周 的实训教学,以提高学生对算法的理解和程序设计的 能力。
1.插入算法
线性表的插入是指在线性表的第i-1个数据元素和第i个数据元素 之间插入一个新的数据元素(如:b),使长度为n的线性表
(a1 ,…, ai , ai+1 , … , an ) 变成长度为n+1 的线性表: (a1 ,…, ai , b, ai+1 , … , an )
实现算法的函数如下:
● 1.3.1 什么是算法 ● 1.3.2 算法的描述 ● 1.3.3 算法的复杂度
● 本章小结 ● 本章实训
● 1.1 数据结构在程序设计中的作用 要想成为一个专业的开发人员,至少需要以下三个条件: (1) 能够熟练地选择和设计各种数据结构和算法。 (2) 至少要能够熟练地掌握一门程序设计语言。 (3) 熟知所涉及的相关应用领域的知识。 瑞士著名的计算机科学家沃思(N· Wirth)提出了: 算法 + 数据结构 = 程序
数据结构研究数据的逻辑结构和物理结构,并在这种结构上定义相 关的运算,设计实现这些运算的算法,分析算法的效率。
● 1.2.2
数据结构分类
根据数据结构中,各数据元素之间的关系,常用的有以下三种基
本数据结构:
1.线性结构
线性结构中的数据元素之间存在一对一的前后次序关系。 如一年四季中的春、夏、秋、冬。
● 1.3 算法及其描述 算法(Algorithm)是程序设计的精髓,程 序设计的实质就是构造解决问题的算法,将 其解释为计算机语言。 算法的设计取决于数 据的逻辑结构,算法的实现取决于数据的物 理存储结构。
数据结构与算法-西安科技大学精品课程网
2) 尾插法建表
算法思路: (1) 建立带头结点的空单链表L,设一指针r指向线性表表尾L. (2) 按线性表中元素的顺序依次读入数据元素,如果不是结束 标识时,申请结点s,将s结点插入到r所指结点的后面,然后 r指向新的表尾结点s,
L r (a) 建空表 (b) 申请新结点并赋值 ∧ s a1 指向新申请的结点 s->data=a1 L a1 r s (c) 插入第一个结点 ① r->next=s L a1 … + r ai-1 s ai r ∧
说明在顺序表上作插入运算平均需要移动表中一半的数据元素
n 1
n 1
时间复杂度为:O(n)
删除操作
指将表中第i个元素从线性表中去掉, i 的取值范围为:1≤i≤n 步骤: ① 将ai+1~an 顺序向上移动。 ② 修改last指针使之仍 指向最后一个元素。
算法性能分析:
删除算法的时间性能分析:与插入运算相同,其时间主要 消耗在移动表中元素上,删除第 i 个元素时,其后面的元素
② 将x 置入空出的第i个位置;
an
n
…
an
③ 修改last指针,使之仍指 向最后一个元素。
…
MAXSIZE-1 插入前
MAXSIZE-1 插入后
假设在每个位置插入元素的概率相等,即Pi = 1/(n+1),则
1 n Ein pi (n i 1) (n i 1) n 1 i 1 2 i 1
插入运算
线性表的插入是指在 表的第i个位置上插入一 个值为x的新元素,i的取值 范围为1≤i≤n+1。
0 1
a1 a2
0 1
a1 a2
…
…
i-2 i-1 i
数据结构试题答案
第一章概论一、选择题1、研究数据结构就是研究(D )。
A. 数据的逻辑结构B. 数据的存储结构C. 数据的逻辑结构和存储结构D. 数据的逻辑结构、存储结构及其基本操作(研究非数值计算的程序设计问题中,计算机操作对象以及他们之间的关系和操作)2、算法分析的两个主要方面是( A )。
A. 空间复杂度和时间复杂度B. 正确性和简单性C. 可读性和文档性D. 数据复杂性和程序复杂性3、具有线性结构的数据结构是( D )。
(线性结构就是:在非空有限集合中,存在为一个被称为第一个的数据元素和最后一个元素,有除了第一个元素,集合中每一个元素均只有一个前驱,除了最后一个元素有唯一后继)(链表、栈、队列、数组、串)A. 图B. 树C. 广义表(线性表的推广)D. 栈4、计算机中的算法指的是解决某一个问题的有限运算序列,它必须具备输入、输出、(B )等5个特性。
A. 可执行性、可移植性和可扩充性B. 可执行性、有穷性和确定性C. 确定性、有穷性和稳定性D. 易读性、稳定性和确定性5、下面程序段的时间复杂度是( C )。
for(i=0;i<m;i++)for(j=0;j<n;j++)a[i][j]=i*j;A. O(m2)B. O(n2)C. O(m*n)D. O(m+n)6、算法是(D )。
为了解决某一问题而规定的一个有限长的操作序列A. 计算机程序B. 解决问题的计算方法C. 排序算法D. 解决问题的有限运算序列7、某算法的语句执行频度为(3n+nlog2n+n2+8),其时间复杂度表示(C )。
A. O(n)B. O(nlog2n)C. O(n2)D. O(log2n)8、下面程序段的时间复杂度为( C )。
i=1;while(i<=n)i=i*3;A. O(n)B. O(3n)C. O(log3n)D. O(n3)9、数据结构是一门研究非数值计算的程序设计问题中计算机的数据元素以及它们之间的(B )和运算等的学科。
《数据结构》填空作业题(答案)
《数据结构》填空作业题答案第1章绪论(已校对无误)1.数据结构包括数据的逻辑结构、数据的存储结构和数据的运算三方面的内容。
2.程序包括两个内容:数据结构和算法。
3. 数据结构的形式定义为:数据结构是一个二元组:Data Structure =(D,S)。
4. 数据的逻辑结构在计算机存储器内的表示,称为数据的存储结构。
5. 数据的逻辑结构可以分类为线性结构和非线性结构两大类。
6. 在图状结构中,每个结点的前驱结点数和后继结点数可以有多个。
7. 在树形结构中,数据元素之间存在一对多的关系。
8. 数据的物理结构,指数据元素在计算机中的标识(映象),也即存储结构。
9. 数据的逻辑结构包括线性结构、树形结构和图形结构3种类型,树型结构和有向图结构合称为非线性结构。
10. 顺序存储结构是把逻辑上相邻的结点存储在物理上连续的存储单元里,结点之间的逻辑关系由存储单元位置的邻接关系来体现。
11. 链式存储结构是把逻辑上相邻的结点存储在物理上任意的存储单元里,节点之间的逻辑关系由附加的指针域来体现。
12. 数据的存储结构可用4种基本的存储方法表示,它们分别是顺序存储、链式存储、索引存储和散列存储。
13. 线性结构反映结点间的逻辑关系是一对一的,非线性结构反映结点间的逻辑关系是一对多或多对多。
14. 数据结构在物理上可分为顺序存储结构和链式存储结构。
15. 我们把每种数据结构均视为抽象类型,它不但定义了数据的表示方式,还给出了处理数据的实现方法。
16. 数据元素可由若干个数据项组成。
17. 算法分析的两个主要方面是时间复杂度和空间复杂度。
18. 一个算法的时间复杂度是用该算法所消耗的时间的多少来度量的,一个算法的空间复杂度是用该算法在运行过程中所占用的存储空间的大小来度量的。
19. 算法具有如下特点:有穷性、确定性、可行性、输入、输出。
20. 对于某一类特定的问题,算法给出了解决问题的一系列操作,每一操作都有它的确切的定义,并在有穷时间内计算出结果。
2013年-数据结构-复习题
第一部分:数据结构——线性结构(顺序表、链表、栈、队列、数组、串)考点:1、时间复杂度2、数据的逻辑结构与存储结构相关知识——分类、与存储结构之间的关系3、顺序表的知识——特点4、链表的知识——编程求单链表中结点的个数、插入、删除。
5、栈与队列知识——特点、循环队列、基本术语、链队列6、数组与矩阵——求元素的地址、稀疏矩阵行优先存储:下标从1开始:Loc(A i,j) = Loc(A1,1)+[(i-1)*n+j-1]*b下标从0开始:Loc(A i,j) = Loc(A0,0)+(i*n+j)*b 列优先存储:下标从1开始:Loc(A i,j) = Loc(A1,1)+[(j-1)*m+i-1]*b下标从0开始:Loc(A i,j) = Loc(A0,0)+(j*m+i)*b1. 设顺序线性表中有n个数据元素,则第i个位置上插入一个数据元素需要移动表中___________个数据元素;删除第i个位置上的数据元素需要移动表中___________个元素。
2.数据的逻辑结构通常有集合、线性结构、_________ 和 _________ 四类结构。
3.若进栈序列为a、b、c ,且进栈和出栈可以穿插进行,则可能出现_________个不同的出栈序列。
4.在栈结构中,允许插入的一端称为 _________;在队列结构中,允许删除的一端称为 _________。
5. 下列程序段的时间复杂度为_____________s=0;for(i=1;i<n;i++)for(j=1;j<n;j++)s+=i*j;6. 假设某个带头结点的单链表的头指针为head,则判定该表为空表的条件()A、head= =NULLB、head->next= =NULLC、head!=NULLD、head->next= =head7. 栈是一种操作受限的线性结构,其操作的主要特点是()A、先进先出B、后进先出C、进优于出D、出优于进8. 假设以数组A[n]存放循环队列的元素,其头、尾指针分别为front和rear。
数据结构严蔚敏(全部章节814张PPT)-(课件)
② 线性结构:结构中的数据元素之间存在一对一的 关系。
③ 树型结构:结构中的数据元素之间存在一对多的 关系。
④ 图状结构或网状结构:结构中的数据元素之间存 在多对多的关系。
图1-3 四类基本结构图
1.1.3 数据结构的形式定义
数据结构的形式定义是一个二元组: Data-Structure=(D,S)
计算机求解问题的一般步骤
编写解决实际问题的程序的一般过程:
– 如何用数据形式描述问题?—即由问题抽象出一个 适当的数学模型; – 问题所涉及的数据量大小及数据之间的关系; – 如何在计算机中存储数据及体现数据之间的关系? – 处理问题时需要对数据作何种运算? – 所编写的程序的性能是否良好? 上面所列举的问题基本上由数据结构这门课程来回答。
其中:D是数据元素的有限集,S是D上关系的有限集。 例2:设数据逻辑结构B=(K,R)
K={k1, k2, …, k9} R={ <k1, k3>,<k1, k8>,<k2, k3>,<k2, k4>,<k2, k5>,<k3, k9>, <k5, k6>,<k8, k9>,<k9, k7>,<k4, k7>,<k4, k6> } 画出这逻辑结构的图示,并确定那些是起点,那些是终点
<基本操作名>(<参数表>) 初始条件: <初始条件描述> 操作结果: <操作结果描述>
– 初始条件:描述操作执行之前数据结构和参数应 满足的条件;若不满足,则操作失败,返回相应的出 错信息。
数据结构C语言版(第2版)严蔚敏人民邮电出版社课后习题答案
数据结构( C语言版)(第 2版)课后习题答案李冬梅2015.3目录第 1 章绪论 (1)第 2 章线性表 (5)第 3 章栈和队列 (13)第 4 章串、数组和广义表 (26)第 5 章树和二叉树 (33)第 6 章图 (43)第 7 章查找 (54)第 8 章排序 (65)第1章绪论1.简述下列概念:数据、数据元素、数据项、数据对象、数据结构、逻辑结构、存储结构、抽象数据类型。
答案:数据:是客观事物的符号表示,指所有能输入到计算机中并被计算机程序处理的符号的总称。
如数学计算中用到的整数和实数,文本编辑所用到的字符串,多媒体程序处理的图形、图像、声音、动画等通过特殊编码定义后的数据。
数据元素:是数据的基本单位,在计算机中通常作为一个整体进行考虑和处理。
在有些情况下,数据元素也称为元素、结点、记录等。
数据元素用于完整地描述一个对象,如一个学生记录,树中棋盘的一个格局(状态)、图中的一个顶点等。
数据项:是组成数据元素的、有独立含义的、不可分割的最小单位。
例如,学生基本信息表中的学号、姓名、性别等都是数据项。
数据对象:是性质相同的数据元素的集合,是数据的一个子集。
例如:整数数据对象是集合N={0 ,± 1,± 2,, } ,字母字符数据对象是集合C={‘A’,‘B’, , ,‘Z’,‘ a’,‘ b’, , ,‘z ’} ,学生基本信息表也可是一个数据对象。
数据结构:是相互之间存在一种或多种特定关系的数据元素的集合。
换句话说,数据结构是带“结构”的数据元素的集合,“结构”就是指数据元素之间存在的关系。
逻辑结构:从逻辑关系上描述数据,它与数据的存储无关,是独立于计算机的。
因此,数据的逻辑结构可以看作是从具体问题抽象出来的数学模型。
存储结构:数据对象在计算机中的存储表示,也称为物理结构。
抽象数据类型:由用户定义的,表示应用问题的数学模型,以及定义在这个模型上的一组操作的总称。
具体包括三部分:数据对象、数据对象上关系的集合和对数据对象的基本操作的集合。
数据结构课后答案第3章
第 3 章特殊线性表——栈、队列和串2005-07-14第 3 章特殊线性表——栈、队列和串课后习题讲解1. 填空⑴设有一个空栈,栈顶指针为1000H,现有输入序列为1、2、3、4、5,经过push,push,pop,push,pop,push,push后,输出序列是(),栈顶指针为()。
【解答】23,1003H⑵栈通常采用的两种存储结构是();其判定栈空的条件分别是(),判定栈满的条件分别是()。
【解答】顺序存储结构和链接存储结构(或顺序栈和链栈),栈顶指针top= -1和top=NULL,栈顶指针top等于数组的长度和内存无可用空间⑶()可作为实现递归函数调用的一种数据结构。
【解答】栈【分析】递归函数的调用和返回正好符合后进先出性。
⑷表达式a*(b+c)-d的后缀表达式是()。
【解答】abc+*d-【分析】将中缀表达式变为后缀表达式有一个技巧:将操作数依次写下来,再将算符插在它的两个操作数的后面。
⑸栈和队列是两种特殊的线性表,栈的操作特性是(),队列的操作特性是(),栈和队列的主要区别在于()。
【解答】后进先出,先进先出,对插入和删除操作限定的位置不同⑹循环队列的引入是为了克服()。
【解答】假溢出⑺数组Q[n]用来表示一个循环队列,front为队头元素的前一个位置,rear为队尾元素的位置,计算队列中元素个数的公式为()。
【解答】(rear-front+n)% n【分析】也可以是(rear-front)% n,但rear-front的结果可能是负整数,而对一个负整数求模,其结果在不同的编译器环境下可能会有所不同。
⑻用循环链表表示的队列长度为n,若只设头指针,则出队和入队的时间复杂度分别是()和()。
【解答】O(1),O(n)【分析】在带头指针的循环链表中,出队即是删除开始结点,这只需修改相应指针;入队即是在终端结点的后面插入一个结点,这需要从头指针开始查找终端结点的地址。
⑼串是一种特殊的线性表,其特殊性体现在()。
数据结构知识点归纳
一、数据结构的章节结构及重点构成数据结构学科的章节划分基本上为:概论,线性表,栈和队列,串,多维数组和广义表,树和二叉树,图,查找,内排,外排,文件,动态存储分配。
对于绝大多数的学校而言,“外排,文件,动态存储分配”三章基本上是不考的,在大多数高校的计算机本科教学过程中,这三章也是基本上不作讲授的。
数据结构的章节比重大致为:1.概论:概念,时间复杂度。
2.线性表:基础章节,必考内容之一。
概念,算法设计题。
3.栈和队列:基本概念。
4.串:基本概念。
5.多维数组及广义表: 基本概念。
6.树和二叉树:重点难点章节,各校必考章节。
概念,问答,算法设计题。
7.图:重点难点章节,各校必考章节。
概念,问答,算法设计题。
8.查找:重点难点章节,概念,问答。
9.排序:重点难点章节,问答各种排序算法的排序过程二、各章节的主要内容:第一章概述主要内容:本章主要起到总领作用,为读者进行数据结构的学习进行了一些先期铺垫。
大家主要注意以下几点: (1)数据结构的基本概念。
(数据;数据元素;数据项;数据结构;数据的逻辑结构:线性和非线性,具体分为集合、线性结构、树形结构和图状结构;数据的存储结构:顺序存储和链式存储;运算)(2)算法的度量:时间效率和空间效率,分别用时间复杂度和空间复杂度度量,掌握时间复杂度的度量方法量方法。
(大O表示法)参考题目:填空题:1、数据结构是相互之间存在一种或多种特定关系的数据元素的集合,它包括三方面的内容,分别是数据的逻辑结构、()和()。
2、数据结构按逻辑结构可分为两大类,它们分别是()和()3. 数据的物理结构主要包括()和()两种情况。
4.线性表,栈,队列和二叉树四种数据结构中()是非线性结构,()是线性结构。
5、线性结构中元素之间存在()关系,树形结构中元素之间存在()关系,图形结构中元素之间存在()关系。
6、程序段的时间复杂度是_______。
for(i=1;i<=n;i++){ k++;for(j=1;j<=n;j++)x=x+k;}7.下列算法的时间复杂度是_____。
罗文劼《数据结构与算法》第4版-第3章课后习题参考答案
第3章线性结构的扩展1.选择题(1)B (2)A (3)DAB (4)CCC (5)C2.判断题(1)Ⅹ(2)√(3)√(4)√(5)Ⅹ(6)Ⅹ(7)Ⅹ(8)Ⅹ(9)Ⅹ(10)Ⅹ3.简答题1.KMP算法较朴素的模式匹配算法有哪些改进?【解答】KMP算法主要优点是主串指针不回溯。
当主串很大不能一次读入内存且经常发生部分匹配时,KMP 算法的优点更为突出。
2.设字符串S=‘aabaabaabaac',P=‘aabaac'。
(1)给出S和P的next值和nextval值;(2)若S作主串,P作模式串,试给出利用KMP算法的匹配过程。
【解答】(1)S的next与nextval值分别为012123456789和002002002009,p的next与nextval值分别为012123和002003。
(2)利用BF算法的匹配过程:利用KMP算法的匹配过程:第一趟匹配:aabaabaabaac 第一趟匹配:aabaabaabaacaabaac(i=6,j=6) aabaac(i=6,j=6)第二趟匹配:aabaabaabaac 第二趟匹配:aabaabaabaacaa(i=3,j=2) (aa)baac第三趟匹配:aabaabaabaac 第三趟匹配:aabaabaabaaca(i=3,j=1) (成功) (aa)baac第四趟匹配:aabaabaabaacaabaac(i=9,j=6)第五趟匹配:aabaabaabaacaa(i=6,j=2)第六趟匹配:aabaabaabaaca(i=6,j=1)第七趟匹配:aabaabaabaac(成功) aabaac(i=13,j=7)3.考虑对KMP算法能否再做改进。
【解答】4.说明一维数组与有序表的异同。
【解答】数组:数组是由类型名、标识符和维数组成的符合数据类型,类型名规定了存放在数组中的元素的类型,而维数则指数组中包含的元素个数。
线性表:(亦作有序表)是最基本、最简单、也是最常用的一种数据结构。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
3)、联接 char *strcat(char *to,char *from); //将from串复制到to串的末尾,并返回to串开始处 的指针 【例】 strcat(s3,"\"); //s3="d:\datastruture\" strcat(s3,s2); //s3="d:\datastruture\string.c"
对于三角矩阵的压缩存储于上述相似。
5、稀疏矩阵的压缩存储
• 稀疏矩阵
设矩阵Amn中有t个非零元素,若t远远小于矩阵元 素的总数(即t<<m×n),则称A为稀疏矩阵。 • 三元组表 将表示稀疏矩阵的非零元素的三元组按行优先(或列优 先)的顺序排列(跳过零元素),并依次存放在向量中,这种 稀疏矩阵的顺序存储结构称为三元组表。 为了表示唯一性,除了每一个非零元素用一个三元组 表示外,在所有表示非零元素的三元组之前再添加一个三 元组:(I,J,t) 其中I表示稀疏矩阵的总行数,J表示稀疏矩阵的总列 数,t表示稀疏矩阵中非零元素的个数。
3.5 其他线性结构 -----数组和串
1、 数组的定义
• 是线性表在含义上的扩展:表中的数据元 素本身也是一个数据结构。 • 是一种复杂的非线性结构,它们的逻辑特
征是:一个数据元素可能有多个直接前驱
和多个直接后继。
2、二维数组
二维数组Am,n可视为由m个行向量组成的向量,或由n个 列向量组成的向量。
4、矩阵的压缩存储
• 矩阵中非零元素呈某种规律分布或者矩阵中出 现大量的零元素的情况下,为了节省存储空间, 我们可以对这类矩阵进行压缩存储:
A、即为多个相同的非零元素只分配一个存储空间; B、对零元素不分配空间。
4、矩阵的压缩存储
一)、特殊矩阵 指非零元素或零元素的分布有一定规律的 矩阵。常见的有对称矩阵、三角矩阵和对角矩 阵等。
4、矩阵的压缩存储
(1)对称矩阵
在一个n阶方阵A中,若元素满足下述性质: aij=aji (i≥0,j≤n-1) 则称A为对称矩阵。
4、矩阵的压缩存储
(2)对称矩阵的压缩存储 对称矩阵中的元素关于主对角线对称,故只要 存储矩阵中上三角或下三角中的元素,让每两个对 称的元素共享一个存储空间。这样,则可将n2个元素 压缩存储到n(n+1)/2个单元中,大致能够节约近一 半的存储空间。
6、 串(String)的基本概念
• 子串和主串 串中任意个连续字符组成的子序列称为该串的子串。 包含子串的串相应地称为主串。 通常将子串在主串中首次出现时,该子串首字符对应 的主串中的序号定义为子串在主串中的序号(或位置)。 【例】设A和B分别为 A="This is a string" B="is" 则B是A的子串,B在A中出现了两次。其中首次出现 对应的主串位置是3。因此称B在A中的序号(或位置)是3。 注意: ①空串是任意串的子串; ②任意串是其自身的子串。
下面以C语言中串运算介绍串的基本运算。
1)、求串长 int strlen(char *s);//求串s的长度 【例】 printf("%d",strlen(s1)); //输出s1的串长15
2)、串复制 char strcpy(char *to, char *from); // 将from串复制到to串中,并返回to开始处的指针 【例】 strcpy(s3,s1); // s3="d:\datastruture",s1串不变
aij
a00 a10 a11 a20 a21 a22 a30
……
a42 a43 a44
5 0 12 11 13 8 7 21 4 1 9 11 6 10 23
0 1 2
……
sk
n(n+1)/2
4、矩阵的压缩存储
• 二维数组aij与一维数组sk之间存在着一一对应 的关系:(行主序、下三角存储方式)
下标以0开始
4)、串比较 int strcmp(char *s1,char *s2); //比较s1和s2的大小,当s1<s2、s1>s2和s1=s2 时, //分别返回小于0、大于0和等于0的值; 【例】 result=strcmp("baker","Baker"); //result>0 result=strcmp("12","12"); //result=0 result=strcmp("Joe","joseph") //result<0
作 业
• 写程序综合以上串的基本操作,调试并 运行得出结果
小结
1. 线性结构的逻辑特征是什么? 2. 顺序表的表长如何计算?动态链表如何 定位? 3. 堆栈和队列各具备什么特性?为什么? 4. 队列什么时候会出现“假溢出”现象? 怎么解决? 5. 二维数组的存储机制是什么?什么时候 采用压缩存储,要注意些什么? 6. 串是特殊的线性表结构,为什么特殊?
【例】左所示的稀疏矩阵A的三元组表示见右 表格。
4 0 2 2 3 5 2 0 4 2 4 12 3 70 51
6、串(String)的基本概念
• 串是一种特殊的线性表,是零个或多个字符组成的有限序 列。一般记为: S=“a0a1……an-1” 其中: ①S是串名; ②双引号括起的字符序列是串值; ③将串值括起来的双引号本身不属于串,它的作用是避 免串与常数或与标识符混淆。 【例】“123”是数字字符串,它不同于整常数123; 【例】“xl”是长度为2的字符串。 ④ai(0≤i≤n-1)可以是字母、数字或其它字符; ⑤串中所包含的字符个数称为该串的长度。
3、数组的顺序表示和实现
2)以列序为主序
将数组元素按列向量排列,第j+1个列向量 紧接在第j个列向量后面。
【例】二维数组Am,n的按列优先存储的线性序列为: a00,a10,…,am-1,0,a01,a11,…,am1,1,…,a0,n-1, a1,n-1,…,am-1,n-1; LOC[aij]=LOC[a00]+(m*j+i)*S
5)、字符定位 char *strchr(char *s,char c); //找c在字符串s中第一次出现的位置, //若找到,则返回该位置,否则返回NULL 【例】 p=strchr(s2,'.'); //p指向"string"之后的位置. 注意: ①上述操作是最基本的,其中后 3个操作还有变种 形式:strncpy,strncat,strncmp和strstr。 ②其它的串操作见C的<string.h>。在不同的高级语 言中,对串运算的种类及符号都不尽相同 ③其余的串操作一般可由这些基本操作组合而成
7、串的基本运算
对于串的基本运算,很多高级语言均提供相应的运算 符或标准的库函数来实现。 为叙述方便,先定义几个相关的变量: char s1[20]="d:\datastruture"; char s2[20]="string.c"; char s3[30]; char *p; int result;
二维数组中的每个元素aij既属于第i行的行向量,又属于第j 列的列向量。
3、数组的顺序表示和实现
1)以行序为主序 将数组元素按行向量排列,第i+1个行向量紧接在第i 个行向量后面。
【例】二维数组Am,n的按行优先存储的线性序列为: a00,a01,…,a0,n-1,a10,a11,…,a1,n-1,…,am1,0,am-1,1,…,am-1,n-1; 元素aij的存储位置: LOC[aij]=LOC[a00]+(n*i+j)*S 每个数据元素占S个存储单元 ; LOC[a00]是a00的位置,也称基地址;