数据结构(C语言版)期末复习
数据结构(c语言版)复习资料
抽出时间去学习,凡事从小做起,不怕单调和重复,长期的积累坚持,想不成功,也难。
数据结构复习资料一、填空题1. 数据结构是一门研究非数值计算的程序设计问题中计算机的 操作对象 以及它们之间的 关系 和运算等的学科2. 数据结构被形式地定义为(DR)其中D是 数据元素 的有限集合R是D上的 关系 有限集合3. 数据结构包括数据的 逻辑结构 、数据的 存储结构 和数据的 运算 这三个方面的内容4. 数据结构按逻辑结构可分为两大类它们分别是 线性结构 和 非线性结构5. 线性结构中元素之间存在一对一关系树形结构中元素之间存在一对多关系图形结构中元素之间存在多对多关系6. 在线性结构中第一个结点 没有 前驱结点其余每个结点有且只有 1个前驱结点;最后一个结点 没有 后续结点其余每个结点有且只有1个后续结点7. 在树形结构中树根结点没有 前驱 结点其余每个结点有且只有 1 个前驱结点;叶子结点没有 后续 结点其余每个结点的后续结点数可以任意多个8. 在图形结构中每个结点的前驱结点数和后续结点数可以 任意多个9.数据的存储结构可用四种基本的存储方法表示它们分别是顺序 、 链式 、 索引 和 散列10. 数据的运算最常用的有5种它们分别是插入 、 删除、修改、 查找 、排序11. 一个算法的效率可分为 时间 效率和 空间 效率12. 在顺序表中插入或删除一个元素需要平均移动 表中一半元素具体移动的元素个数与 表长和该元素在表中的位置 有关13. 线性表中结点的集合是 有限 的结点间的关系是 一对一 的14. 向一个长度为n的向量的第i个元素(1≤i≤n+1)之前插入一个元素时需向后移动 n-i+1 个元素15. 向一个长度为n的向量中删除第i个元素(1≤i≤n)时需向前移动 n-i 个元素16. 在顺序表中访问任意一结点的时间复杂度均为 O(1)因此顺序表也称为 随机存取 的数据结构17. 顺序表中逻辑上相邻的元素的物理位置 必定相邻单链表中逻辑上相邻的元素的物理位置 不一定 相邻18.在单链表中除了首元结点外任一结点的存储位置由 其直接前驱结点的链域的值 指示19. 在n个结点的单链表中要删除已知结点*p需找到它的前驱结点的地址其时间复杂度为O(n)20. 向量、栈和队列都是 线性 结构可以在向量的 任何 位置插入和删除元素;对于栈只能在 栈顶 插入和删除元素;对于队列只能在 队尾 插入和 队首 删除元素21. 栈是一种特殊的线性表允许插入和删除运算的一端称为 栈顶不允许插入和删除运算的一端称为 栈底22. 队列 是被限定为只能在表的一端进行插入运算在表的另一端进行删除运算的线性表23. 不包含任何字符(长度为0)的串 称为空串; 由一个或多个空格(仅由空格符)组成的串 称为空白串24. 子串的定位运算称为串的模式匹配; 被匹配的主串 称为目标串子串 称为模式25. 假设有二维数组A6×8每个元素用相邻的6个字节存储存储器按字节编址已知A的起始存储位置(基地址)为1000则数组A的体积(存储量)为 288 B ;末尾元素A57的第一个字节地址为 1282 ;若按行存储时元素A14的第一个字节地址为 (8+4)×6+1000=1072 ;若按列存储时元素A47的第一个字节地址为 (6×7+4)×6+1000)=1276 26. 由3个结点所构成的二叉树有 5 种形态27. 一棵深度为6的满二叉树有 n1+n2=0+ n2= n0-1=31 个分支结点和 26-1 =32 个叶子注:满二叉树没有度为1的结点所以分支结点数就是二度结点数28. 一棵具有257个结点的完全二叉树它的深度为 9( 注:用? log2(n) ?+1= ? 8.xx ?+1=929.设一棵完全二叉树有700个结点则共有 350 个叶子结点 答:最快方法:用叶子数=[n/2]=35030. 设一棵完全二叉树具有1000个结点则此完全二叉树有 500 个叶子结点有 499 个度为2的结点有 1 个结点只有非空左子树有 0 个结点只有非空右子树答:最快方法:用叶子数=[n/2]=500n2=n0-1=499另外最后一结点为2i属于左叶子右叶子是空的所以有1个非空左子树完全二叉树的特点决定不可能有左空右不空的情况所以非空右子树数=0.31.在数据的存放无规律而言的线性表中进行检索的最佳方法是 顺序查找(线性查找)32. 线性有序表(a1a2a3...a256)是从小到大排列的对一个给定的值k用二分法检索表中与k相等的元素在查找不成功的情况下最多需要检索 8 次设有100个结点用二分法查找时最大比较次数是 733. 假设在有序线性表a[20]上进行折半查找则比较一次查找成功的结点数为1;比较两次查找成功的结点数为 2 ;比较四次查找成功的结点数为 8 ;平均查找长度为 3.7解:显然平均查找长度=O(log2n)<5次(25)但具体是多少次则不应当按照公式来计算(即(21×log221)/20=4.6次并不正确!)因为这是在假设n=2m-1的情况下推导出来的公式应当用穷举法罗列:全部元素的查找次数为=(1+2×2+4×3+8×4+5×5)=74; ASL =74/20=3.7 !!!34.折半查找有序表(4612202838507088100)若查找表中元素20它将依次与表中元素 2861220 比较大小35. 在各种查找方法中平均查找长度与结点个数n无关的查找方法是 散列查找36. 散列法存储的基本思想是由 关键字的值 决定数据的存储地址二、判断正误(在正确的说法后面打勾反之打叉)( × )1. 链表的每个结点中都恰好包含一个指针答:错误链表中的结点可含多个指针域分别存放多个指针例如双向链表中的结点可以含有两个指针域分别存放指向其直接前趋和直接后继结点的指针( × )2. 链表的物理存储结构具有同链表一样的顺序错链表的存储结构特点是无序而链表的示意图有序( × )3. 链表的删除算法很简单因为当删除链中某个结点后计算机会自动地将后续的各个单元向前移动错链表的结点不会移动只是指针内容改变( × )4. 线性表的每个结点只能是一个简单类型而链表的每个结点可以是一个复杂类型 错混淆了逻辑结构与物理结构链表也是线性表!且即使是顺序表也能存放记录型数据( × )5. 顺序表结构适宜于进行顺序存取而链表适宜于进行随机存取错正好说反了顺序表才适合随机存取链表恰恰适于"顺藤摸瓜"( × )6. 顺序存储方式的优点是存储密度大且插入、删除运算效率高错前一半正确但后一半说法错误那是链式存储的优点顺序存储方式插入、删除运算效率较低在表长为n的顺序表中插入和删除一个数据元素平均需移动表长一半个数的数据元素( × )7. 线性表在物理存储空间中也一定是连续的 错线性表有两种存储方式顺序存储和链式存储后者不要求连续存放( × )8. 线性表在顺序存储时逻辑上相邻的元素未必在存储的物理位置次序上相邻错误线性表有两种存储方式在顺序存储时逻辑上相邻的元素在存储的物理位置次序上也相邻( × )9. 顺序存储方式只能用于存储线性结构错误顺序存储方式不仅能用于存储线性结构还可以用来存放非线性结构例如完全二叉树是属于非线性结构但其最佳存储方式是顺序存储方式(后一节介绍)( × )10. 线性表的逻辑顺序与存储顺序总是一致的 错理由同7链式存储就无需一致( × )11. 线性表的每个结点只能是一个简单类型而链表的每个结点可以是一个复杂类型错线性表是逻辑结构概念可以顺序存储或链式存储与元素数据类型无关( × )12. 在表结构中最常用的是线性表栈和队列不太常用错不一定吧?调用子程序或函数常用CPU中也用队列( √ )13. 栈是一种对所有插入、删除操作限于在表的一端进行的线性表是一种后进先出型结构( √ )14. 对于不同的使用者一个表结构既可以是栈也可以是队列也可以是线性表正确都是线性逻辑结构栈和队列其实是特殊的线性表对运算的定义略有不同而已( × )15. 栈和链表是两种不同的数据结构错栈是逻辑结构的概念是特殊殊线性表而链表是存储结构概念二者不是同类项( × )16. 栈和队列是一种非线性数据结构错他们都是线性逻辑结构栈和队列其实是特殊的线性表对运算的定义略有不同而已( √ )17. 栈和队列的存储方式既可是顺序方式也可是链接方式( √ )18. 两个栈共享一片连续内存空间时为提高内存利用率减少溢出机会应把两个栈的栈底分别设在这片内存空间的两端( × )19. 队是一种插入与删除操作分别在表的两端进行的线性表是一种先进后出型结构错后半句不对( × )20. 一个栈的输入序列是12345则栈的输出序列不可能是12345错有可能( √ )21. 若二叉树用二叉链表作存贮结构则在n个结点的二叉树链表中只有n-1个非空指针域( × )22.二叉树中每个结点的两棵子树的高度差等于1( √ )23.二叉树中每个结点的两棵子树是有序的( × )24.二叉树中每个结点有两棵非空子树或有两棵空子树( × )25.二叉树中每个结点的关键字值大于其左非空子树(若存在的话)所有结点的关键字值且小于其右非空子树(若存在的话)所有结点的关键字值(应当是二叉排序树的特点)( × )26.二叉树中所有结点个数是2k-1-1其中k是树的深度(应2i-1)( × )27.二叉树中所有结点如果不存在非空左子树则不存在非空右子树( × )28.对于一棵非空二叉树它的根结点作为第一层则它的第i层上最多能有2i-1个结点(应2i-1)( √ )29.用二叉链表法(link-rlink)存储包含n个结点的二叉树结点的2n个指针区域中有n+1个为空指针( √ )30.具有12个结点的完全二叉树有5个度为2的结点三、单项选择题( B )1. 非线性结构是数据元素之间存在一种: A)一对多关系 B)多对多关系 C)多对一关系 D)一对一关系( C )2. 数据结构中与所使用的计算机无关的是数据的 结构; A) 存储 B) 物理 C) 逻辑 D) 物理和存储( C )3. 算法分析的目的是: A) 找出数据结构的合理性 B) 研究算法中的输入和输出的关系 C) 分析算法的效率以求改进 D) 分析算法的易懂性和文档性( A )4. 算法分析的两个主要方面是: A) 空间复杂性和时间复杂性 B) 正确性和简明性 C) 可读性和文档性 D) 数据复杂性和程序复杂性( C )5. 计算机算法指的是: A) 计算方法 B) 排序方法 C) 解决问题的有限运算序列 D) 调度方法( B )6. 计算机算法必须具备输入、输出和 等5个特性 A) 可行性、可移植性和可扩充性 B) 可行性、确定性和有穷性 C) 确定性、有穷性和稳定性 D) 易读性、稳定性和安全性( C )7.数据在计算机存储器内表示时物理地址与逻辑地址相同并且是连续的称之为:(A)存储结构 (B)逻辑结构 (C)顺序存储结构 (D)链式存储结构( B )8.一个向量第一个元素的存储地址是100每个元素的长度为2则第5个元素的地址是 (A)110 (B)108 (C)100 (D)120( A )9. 在n个结点的顺序表中算法的时间复杂度是O(1)的操作是:(A) 访问第i个结点(1≤i≤n)和求第i个结点的直接前驱(2≤i≤n)(B) 在第i个结点后插入一个新结点(1≤i≤n)(C) 删除第i个结点(1≤i≤n)(D) 将n个结点从小到大排序( B )10. 向一个有127个元素的顺序表中插入一个新元素并保持原来顺序不变平均要移动 个元素 (A)8 (B)63.5 (C)63 (D)7( A )11. 链接存储的存储结构所占存储空间:(A) 分两部分一部分存放结点值另一部分存放表示结点间关系的指针(B) 只有一部分存放结点值(C) 只有一部分存储表示结点间关系的指针 (D) 分两部分一部分存放结点值另一部分存放结点所占单元数( B )12. 链表是一种采用 存储结构存储的线性表; (A)顺序 (B)链式 (C)星式 (D)网状( D )13. 线性表若采用链式存储结构时要求内存中可用存储单元的地址:(A)必须是连续的 (B)部分地址必须是连续的(C)一定是不连续的 (D)连续或不连续都可以( B )14. 线性表L在 情况下适用于使用链式结构实现 (A)需经常修改L中的结点值 (B)需不断对L进行删除插入 (C)L中含有大量的结点 (D)L中结点结构复杂( B )15.栈中元素的进出原则是A.先进先出 B.后进先出 C.栈空则进 D.栈满则出( C )16. 若已知一个栈的入栈序列是123...其输出序列为p1p2p3...pn若p1=n则pi为A.i B.n=i C.n-i+1 D.不确定( B )17. 判定一个栈ST(最多元素为m0)为空的条件是A.ST->top<>0 B.ST->top=0 C.ST->top<>m0 D.ST->top=m0( C )18. 在一个图中所有顶点的度数之和等于图的边数的 倍A.1/2 B. 1 C. 2 D. 4( B )19. 在一个有向图中所有顶点的入度之和等于所有顶点的出度之和的 倍A.1/2 B. 1 C. 2 D. 4( B )20. 有8个结点的无向图最多有 条边A.14 B. 28 C. 56 D. 112( C )21. 有8个结点的有向完全图有 条边A.14 B. 28 C. 56 D. 112( B )22.在表长为n的链表中进行线性查找它的平均查找长度为A. ASL=n; B. ASL=(n+1)/2;C. ASL=+1; D. ASL≈log2(n+1)-1( A )23.折半查找有序表(4610122030507088100)若查找表中元素58则它将依次与表中 比较大小查找结果是失败 A.20703050 B.30887050 C.2050 D.308850( C )24.对22个记录的有序表作折半查找当查找失败时至少需要比较 次关键字A.3 B.4 C.5 D. 6( A )25. 链表适用于 查找 A.顺序 B.二分法 C.顺序也能二分法 D.随机???? ?? ??1 1。
数据结构(c语言版)复习资料
数据结构(c语言版)复习资料数据结构(C语言版)复习资料数据结构是计算机科学中非常重要的一个领域,它研究的是在计算机中存储、组织和管理数据的方法和技术。
学习数据结构对于提高算法设计和程序开发能力至关重要。
本文将为您提供一份C语言版的数据结构复习资料,帮助您回顾和巩固相关的知识。
1. 数组(Array)数组是一种线性数据结构,它可以在内存中连续存储多个相同类型的元素。
在C语言中,我们可以使用数组来表示并操作一系列的数据。
例如,声明一个整型数组可以使用以下语法:```cint arr[10]; // 声明一个包含10个整数的数组```数组的元素可以通过索引进行访问和修改,索引从0开始,最大为数组长度减1。
数组的优点是可以快速访问任意位置的元素,但其缺点是大小固定,不便于插入和删除操作。
2. 链表(Linked List)链表是一种常见的动态数据结构,它通过节点的指针链接来存储数据。
在每个节点中,除了数据本身外,还包含一个指向下一个节点的指针。
链表分为单向链表和双向链表两种形式。
在C语言中,我们可以使用结构体来定义链表节点:```cstruct Node {int data;struct Node* next; // 指向下一个节点的指针};```链表可以根据需要添加或删除节点,因此插入和删除操作比数组更高效。
但是,链表的访问速度相对较慢,因为它需要从头开始遍历查找元素。
3. 栈(Stack)栈是一种先进后出(Last In First Out,LIFO)的数据结构。
栈可以通过数组或链表来实现。
在C语言中,我们可以使用数组和指针来定义和操作栈。
栈的基本操作包括压入(push)元素和弹出(pop)元素。
压入操作将元素插入栈的顶部,而弹出操作将栈顶的元素移除。
例如,下面是一个使用数组实现的栈的示例代码:```c#define MAX_SIZE 100int stack[MAX_SIZE];int top = -1; // 栈顶指针初始化为-1 void push(int item) {if (top >= MAX_SIZE - 1) {printf("Stack Overflow\n");} else {stack[++top] = item;}}int pop() {if (top <= -1) {printf("Stack Underflow\n");return -1;} else {return stack[top--];}}```4. 队列(Queue)队列是一种先进先出(First In First Out,FIFO)的线性数据结构。
数据结构c语言期末考试题及答案
数据结构c语言期末考试题及答案一、单项选择题(每题2分,共20分)1. 在数据结构中,线性结构和非线性结构的区别在于()。
A. 结构中元素的个数B. 结构中是否包含子结构C. 结构中元素之间是否有一对一关系D. 结构中元素之间是否有一对多关系答案:C2. 线性表的顺序存储结构和链式存储结构相比,其优点是()。
A. 存储密度高B. 存储密度低C. 插入和删除操作快D. 存储空间可以动态分配答案:A3. 在一个长度为n的顺序表中,删除第i个元素(1≤i≤n)时,需要移动的元素个数为()。
A. i-1B. n-iC. n-i+1D. n-i-1答案:B4. 栈的运算遵循()原则。
A. 先进先出B. 先进后出C. 后进先出D. 后进后出答案:C5. 在二叉树的前序遍历中,访问顺序为()。
A. 根-左-右B. 左-根-右C. 左-右-根D. 右-左-根答案:A6. 哈希表的冲突解决方法中,链地址法是()。
A. 将所有元素存储在同一个存储单元B. 将所有元素存储在同一个链表中C. 将所有元素存储在同一个数组中D. 将所有元素存储在同一个链表的同一个位置答案:B7. 在图的遍历中,深度优先搜索(DFS)和广度优先搜索(BFS)的主要区别在于()。
A. 遍历的顺序不同B. 遍历的起点不同C. 遍历的路径不同D. 遍历使用的存储结构不同答案:D8. 快速排序算法的时间复杂度为()。
A. O(n)B. O(nlogn)C. O(n^2)D. O(logn)答案:B9. 归并排序算法的时间复杂度为()。
A. O(n)B. O(nlogn)C. O(n^2)D. O(logn)答案:B10. 在二叉搜索树中,查找一个元素的时间复杂度为()。
A. O(n)B. O(logn)C. O(n^2)D. O(1)答案:B二、填空题(每题2分,共20分)1. 在数据结构中,一个算法的时间复杂度通常用______来描述。
答案:大O符号2. 线性表的两种基本操作是插入和______。
(完整版)数据结构复习题目及答案
《数据结构-C语言版》第一章绪论单项选择题1.在数据结构中,数据的基本单位是_____ ____。
A. 数据项B. 数据类型C. 数据元素D. 数据变量2.数据结构中数据元素之间的逻辑关系被称为__ ____。
A. 数据的存储结构B. 数据的基本操作C. 程序的算法D. 数据的逻辑结构3.在数据结构中,与所使用计算机无关的是数据的____ ___。
A. 存储结构B. 逻辑和物理结构C. 逻辑结构D. 物理结构4.在链式存储结构中,数据之间的关系是通过____ ____体现的。
A. 数据在内存的相对位置B. 指示数据元素的指针C. 数据的存储地址D. 指针5.计算算法的时间复杂度是属于一种____ ___。
A. 事前统计的方法B. 事前分析估算的方法C. 事后统计的方法D. 事后分析估算的方法6.在对算法的时间复杂度进行估计的时候,下列最佳的时间复杂度是____ __。
A. n2B. nlognC. nD. logn7.设使用某算法对n个元素进行处理,所需的时间是T(n)=100nlog2n+200n+2000,则该算法的渐近时间复杂度为____ ___。
A. O(1)B. O(n)C. O(200n)D. O(nlog2n)CDCBBDD第二章线性表单项选择题1.链表不具有的特点是____ ____。
A. 可随机访问任一元素B. 插入和删除时不需要移动元素C. 不必事先估计存储空间D. 所需空间与线性表的长度正比2.设顺序表的每个元素占8个存储单元。
第1个单元的存储地址是100,则第6个元素占用的最后一个存储单元的地址为。
A. 139B. 140C. 147D. 1483.在线性链表存储结构下,插入操作算法。
A. 需要判断是否表满B. 需要判断是否表空C. 不需要判断表满D. 需要判断是否表空和表满4.在一个单链表中,若删除p所指结点的后继结点,则执行。
A. p->next = p->next->next;B. p->next = p->next;C. p = p->next->next;D. p = p->next; p->next = p->next->next;5.将长度为n的单链表接在长度为m的单链表之后的算法时间复杂度为。
数据结构c语言期末考试题库及详解答案
数据结构c语言期末考试题库及详解答案数据结构C语言期末考试题库及详解答案一、选择题1. 在数据结构中,线性表的顺序存储结构被称为:A. 链式存储结构B. 栈C. 队列D. 数组答案:D2. 下列关于栈的描述,错误的是:A. 栈是一种特殊的线性表B. 栈的特点是后进先出C. 栈顶元素是最后插入的元素D. 栈的插入和删除操作都发生在栈顶答案:C二、填空题1. 在C语言中,定义一个具有10个元素的整型数组可以使用语句:________。
答案:int arr[10];2. 链表与数组相比,其优点是________。
答案:动态内存分配,不需要预先知道数据规模三、简答题1. 简述二叉树的遍历方法有哪些,并说明它们的特点。
答案:二叉树的遍历方法主要有前序遍历、中序遍历和后序遍历三种。
前序遍历首先访问根节点,然后递归地遍历左子树和右子树;中序遍历首先遍历左子树,然后访问根节点,最后遍历右子树;后序遍历首先遍历左子树和右子树,最后访问根节点。
每种遍历方法都可以用来对二叉树进行不同的操作和分析。
2. 什么是哈希表?它在实际应用中有哪些优点?答案:哈希表是一种通过哈希函数将键映射到表中一个位置来访问记录的数据结构。
它的优点包括:快速的数据访问速度,因为哈希表通常在常数时间内完成查找;动态的内存分配,可以根据需要调整存储空间;以及灵活的键值对存储方式。
四、编程题1. 编写一个C语言函数,实现单链表的逆序输出。
答案:```c#include <stdio.h>#include <stdlib.h>typedef struct Node {int data;struct Node *next;} Node;void reversePrint(Node *head) {if (head == NULL) return;reversePrint(head->next);printf("%d ", head->data);}int main() {Node *head = (Node *)malloc(sizeof(Node));head->data = 1;head->next = NULL;// 假设链表已经构建完毕reversePrint(head);return 0;}```2. 请实现一个C语言函数,用于计算一个字符串中不同字符的数量。
数据结构(C语言版)复习题
一、单项选择题:1、树形结构不具备这样的特点:()A. 每个节点可能有多个后继(子节点)B. 每个节点可能有多个前驱(父节点)C. 可能有多个内节点(非终端结点)D. 可能有多个叶子节点(终端节点)2、二叉树与度数为2的树相同之处包括()。
A. 每个节点都有1个或2个子节点B. 至少有一个根节点C. 至少有一个度数为2的节点D. 每个节点至多只有一个父节点3、一棵完全二叉树有999 个结点,它的深度为()。
A.9 B.10 C.11 D.124、在一个单链表中,若p所指结点不是最后结点,在p之后插入s所指结点,则执行()A. s->next=p;p->next=s;B. s->next=p->next;p->next=s;C. s->next=p->next;p=s;D. p->next=s;s->next=p;5、对于一棵具有n个结点、度为5的树来说,()A. 树的高度至多是n-3B. 树的高度至多是n-4C. 树的高度至多是nD. 树的高度至多是n-56、在顺序队列中,元素的排列顺序()。
A. 由元素插入队列的先后顺序决定B. 与元素值的大小有关C. 与队首指针和队尾指针的取值有关D. 与数组大小有关7、串是一种特殊的线性表,其特殊性体现在()。
A.可以顺序存储 B.数据元素是一个字符C.可以链式存储 D.数据元素可以是多个字符若8、顺序循环队列中(数组的大小为 6),队头指示 front 和队尾指示 rear 的值分别为 3和 0,当从队列中删除1个元素,再插入2 个元素后,front和 rear的值分别为()。
A.5 和1 B.2和4 C.1和5 D.4 和29、一棵完全二叉树上有1001 个结点,其中叶子结点的个数为()。
A.250 B.500 C.254 D.50110、已知一个有向图如下图所示,则从顶点a出发进行深度优先遍历,不可能得到的DFS序列为()。
数据结构C语言版知识点复习资料
数据结构复习资料一、填空题1. 数据结构是一门研究非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和运算等的学科。
2. 数据结构被形式地定义为(D, R),其中D是数据元素的有限集合,R是D上的关系有限集合。
3. 数据结构包括数据的逻辑结构、数据的存储结构和数据的运算这三个方面的内容。
4. 数据结构按逻辑结构可分为两大类,它们分别是线性结构和非线性结构。
5. 线性结构中元素之间存在一对一关系,树形结构中元素之间存在一对多关系,图形结构中元素之间存在多对多关系。
6.在线性结构中,第一个结点没有前驱结点,其余每个结点有且只有1个前驱结点;最后一个结点没有后续结点,其余每个结点有且只有1个后续结点。
7. 在树形结构中,树根结点没有前驱结点,其余每个结点有且只有 1 个前驱结点;叶子结点没有后续结点,其余每个结点的后续结点数可以任意多个。
8. 在图形结构中,每个结点的前驱结点数和后续结点数可以任意多个。
9.数据的存储结构可用四种基本的存储方法表示,它们分别是顺序、链式、索引和散列。
10. 数据的运算最常用的有5种,它们分别是插入、删除、修改、查找、排序。
11. 一个算法的效率可分为时间效率和空间效率。
12. 在顺序表中插入或删除一个元素,需要平均移动表中一半元素,具体移动的元素个数与表长和该元素在表中的位置有关。
13. 线性表中结点的集合是有限的,结点间的关系是一对一的。
14. 向一个长度为n的向量的第i个元素(1≤i≤n+1)之前插入一个元素时,需向后移动n-i+1 个元素。
15. 向一个长度为n的向量中删除第i个元素(1≤i≤n)时,需向前移动n-i 个元素。
16. 在顺序表中访问任意一结点的时间复杂度均为O(1) ,因此,顺序表也称为随机存取的数据结构。
17. 顺序表中逻辑上相邻的元素的物理位置必定相邻。
单链表中逻辑上相邻的元素的物理位置不一定相邻。
18.在单链表中,除了首元结点外,任一结点的存储位置由其直接前驱结点的链域的值指示。
数据结构c语言版期末考试试题
《数据结构与算法》复习题一、选择题。
20. 如果最常用的操作是取第i个结点及英前驱,则采用D存储方式最节省时间。
A. 单链表B.双链表C.单循环链表D.顺序表21. 在一个具有n个结点的有序单链表中插入一个新结点并仍然保持有序的时间复杂度是B_o)A. O (1)B. O (n)C. O (n2)D. O (nlog2n)27. 下述哪一条是顺序存储结构的优点CA插入运算方便B可方便地用于各种逻辑结构的存储表示C存储密度大D删除运算方便35.在单链表指针为p的结点之后插入指针为s的结点,正确的操作是s->next=p->next : p->next=s;}41.以下 B 不是队列的基本运算A.从队尾插入一个新元素B.从队列中删除第i个元素C.判断一个队列是否为空D.读取队头元素的值47.在循环队列中,若front与rear分别表示对头元素和队尾元素的位置,则判断循环队列空的条件是_ .A. front==rear+lB. rear==front+lC. front==rearD. front==04.向一个栈顶指针为h的带头结点的链栈中插入指针s所指的结点时,应执行s->next=h->next ;h->next=s50.若栈采用顺序存储方式存储,现两栈共享空间V[1 m], top[l]、top[2]分别代表第1和第2个栈的栈顶,栈1的底在V[l],栈2的底在V[m],则栈满的条件是____________________ oA. |top[2]-top[l]|=0B. top[l]+l=top[2]C. top[l]+top[2]=mD. top[l]=top[2]52.允许对队列进行的操作有—。
A.对队列中的元素排序B.取岀最近进队的元素C.在队头元素之前插入元素D.删除队头元素54.若用一个大小为6的数值来实现循环队列,且当前rear和front的值分别为0和3,当从队列中删除一个元素,再加入两个元素后,rear和front的值分别为 B °A. 1 和5B. 2 和4C. 4 和2D. 5 和 156. 和顺序栈相比,链栈有一个比较明显的优势是通常不会出现栈满的情况57. 用不带头结点的单链表存储队列,其头指针指向队头结点,尾指针指向队尾结点,则在进行出队操作时C o C.队头、队尾指针都可能要修改64.若声明一个浮点数数组如卜一:froat average[]=new float[30];假设该数组的内存起始位置为200, average[15]的内存地址是C 。
数据结构c语言期末考试试题及答案
数据结构c语言期末考试试题及答案一、选择题(每题2分,共20分)1. 在C语言中,以下哪个关键字用于定义结构体?A. structB. unionC. enumD. typedef答案:A2. 在C语言中,以下哪个函数用于创建链表节点?A. mallocB. callocC. reallocD. free答案:A3. 如果一个链表的头指针为NULL,这意味着什么?A. 链表为空A. 链表已满C. 链表正在使用中D. 链表已损坏答案:A4. 在C语言中,以下哪个数据结构允许快速随机访问?A. 链表B. 数组C. 栈D. 队列5. 在二叉树中,以下哪个术语描述了没有子节点的节点?A. 根节点B. 叶节点C. 内部节点D. 父节点答案:B6. 以下哪个算法用于在二叉搜索树中查找一个元素?A. 深度优先搜索B. 广度优先搜索C. 插入排序D. 二分查找答案:D7. 在C语言中,以下哪个关键字用于定义一个函数?A. intB. voidC. returnD. struct答案:A8. 以下哪个选项是正确的递归函数定义?A. int fact(int n) { if (n > 1) return n * fact(n-1); else return 1; }B. int fact(int n) { if (n > 1) return n * fact(n); else return 1; }C. int fact(int n) { if (n > 1) return n * fact(n+1); else return 1; }D. int fact(int n) { if (n > 1) return n; else return 1; }9. 在C语言中,以下哪个函数用于释放动态分配的内存?A. mallocB. callocC. reallocD. free答案:D10. 在C语言中,以下哪个关键字用于定义一个指针?A. intB. charC. *D. &答案:C二、填空题(每题2分,共20分)1. 在C语言中,结构体的成员可以通过其结构体变量名和______访问。
数据结构(C语言版)复习要点(含专业术语解释)
一、概念【以下二十个词是概念的考试范围】数据:是对客观事物的符号表示,在计算机科学中是指所有能输入到计算机中并被计算机程序处理的符号的总称。
数据元素:是数据的根本单位,在计算机程序中通常作为一个整体进展考虑和处理数据构造:是互相之间存在一个或多种特定关系的数据元素的集合。
线性表:最常用最简单的一种数据构造,一个线性表是n个数据元素的有限序列队列:是一种先进先出的线性表,它只允许在表的一端进展插入,而另一端删除元素串:由零个或多个字符组成的有限序列完全二叉树:深度为K的,有N个节点的二叉树,当且仅当其没一个结点都与深度为K的满二叉树中编号从1至N的结点一一对应时。
图:多个结点,结点间的关系可以是任意的,图中任意两个元素之间都有可能相关入度:以顶点V为头的弧的数目称为V的入度出度:以V为尾的弧的数目称为V的入度拓扑排序:由某个集合上的一个偏序得到集合上的一个全序的操作二叉排序树:或者是空树,或者是符合以下性质的二叉树1、假设它的左子树不空,那么左子树上所有结点均小于它的根结点值。
2、假设它的右子树不空,那么右子树上所有结点均大于它的根结点值3、它的左右子树也分别是二叉排序树循环链表:是另一种形式的链式存储构造。
它的特点是表中最后一个结点的指针域指向头结点,整个链表形成一个环栈:是限定仅在表尾进展插入或删除操作的线性表二叉树:是一种树型的构造,它的特点是每个结点至多只有两棵子树,且有左右之分,不可任意颠倒满二叉树一颗深度为K且有2的K次方减1个结点的二叉树查找表:是由同一类型的数据元素构成的集合静态查找表:查询某个特定的数据元素是否在查找表中,检索某个特定的数据元素的各种属性。
动态查找表:在查找过程中同时插入查找不存在的数据元素,或者从查找表中删除已存在的某个数据元素排序:是计算机程序设计中的一种重要操作,它的功能是将一个数据元素的任意序列,重新排列成一个关键字的有序序列。
关键字:是数据元素中某个数据项的值,用它可以识别一个数据元素二、算法总体要求:1、要求写算法的题,能写出完好、正确的算法语句总分值;写出主要算法、不完好的也有分;实在不会算法,能用文字明晰描绘的也有分;一个字不写,空白当然没分。
数据结构C语言版复习资料
数据结构C语言版复习资料2一、选择题1.以下数据结构中哪一个是非线性结构?( B )A. 队列B. 二叉树C. 栈D. 线性表2.设输入序列为1、2、3、4、5、6,则通过栈的作用后可以得到的输出序列为( B )。
A. 5,6,3,4,1,2 C. 3,1,2,6,5,4B. 3,2,5,6,4,1 D. 1,5,4,6,2,33.设某二叉树中度数为0的结点数为N0,度数为1的结点数为Nl,度数为2的结点数为N2,则下列等式成立的是( C )。
A. N0=N1+1B. N0=Nl+N2C. N0=N2+1D. N0=2N1+l4.设某棵二叉树中有1000个结点,则该二叉树的最小高度为( B )。
A.9 B. 10 C. 11 D. 125、在一棵具有4层的满二叉树中结点总数为(A )。
A. 15B. 16C. 17D. 326、设一棵二叉树的中序遍历序列:badce,后序遍历序列:bdeca,则二叉树先序遍历序列为(D )。
A. adbceB. decabC. debacD. abcde7.设有8个结点的无向图,该图至少应有( C )条边才能确保是一个连通图。
A. 5B. 6C. 7D. 88.设无向图G中有n个顶点e条边,则其对应的邻接表中的表头结点和表结点的个数分别为( C )。
A. n,eB. 2n,eC. n,2eD. e,n9.设无向图G中的边的集合E={(a,b),(a,e),(a,c),(b,e),(e,d),(d,f),(f,c)},则从顶点b出发进行深度优先遍历可以得到的一种顶点序列为( A )。
A. bacfdeB. becfadC. bacedfD. beafdc二、填空题1.数据元素之间的逻辑结构有四种基本类型,分别是集合、线性、树形结构和网状结构。
2.数据元素之间的存储结构有两种基本类型,分别是顺序存储结构和 链式存储结构 。
3.设输入序列是1、2、3、……、n ,经过栈的作用后输出序列的第一个元素是n ,则输出序列中第i 个输出元素是 n-i+1 。
数据结构(c语言版)复习知识点
第一章绪论1.1数据、数据元素、数据项、数据结构等基本概念1.数据(data):客观事物的符号表示,在计算机科学中指所有能输入计算机中并被计算机处理的符号总称。
整数、浮点数、字符串、声音、图像。
2.数据元素(dataelement):数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。
3.一个数据元素可能由若干个数据项(dataitem)组成。
数据元素是一个数据整体中相对独立的单位。
但它还可以分割成若干个具有不同属性的项(字段)。
故不是组成数据的最小单位。
数据项是构成数据的最小单位。
4.数据对象(dataobject):性质相同的数据元素的集合,是数据的一个子集。
5.数据结构(datastructure):数据元素以及数据元素之间存在的关系。
6.数据结构主要描述:数据元素之间的逻辑关系、数据在计算机系统中的存储方式和数据的运算,即数据的逻辑结构、存储结构和数据的操作集合1.2数据结构的逻辑结构、存储结构的含义及其相互关系1.数据的逻辑结构:用形式化方式描述数据元素间的关系。
数据的逻辑结构独立于计算机,是数据本身所固有的。
用于算法的设计。
两大类逻辑结构:线性结构(线性表、栈、队列、数组和串),非线性结构(树和图)。
2.数据的物理结构(也称存储结构):数据在计算机中的具体表示。
包括数据元素的表示和关系的表示。
存储结构是逻辑结构在计算机存贮器中的映像,必须依赖于计算机。
用于算法的实现。
数据的存储方式可分为如下两类:顺序存储、链接存储。
1.3算法1.算法的定义:算法是对特定问题求解步骤的一种描述,是指令的有限序列。
2.算法的特性:有穷性——算法必须在执行有穷步之后结束,而且每一步都可在有穷时间内完成确定性——每条指令无二义性。
并且,相同的输入只能得到相同的输出;可行性——算法中描述的每一操作,都可以通过已实现的基本运算来实现。
输入——算法有零至多个输入。
输出——算法有一个至多个输出3.算法效率的度量:时间复杂度和空间复杂度及计算。
数据结构c语言期末试题及答案
数据结构c语言期末试题及答案一、单项选择题(每题2分,共20分)1. 在C语言中,以下哪个关键字用于定义一个结构体?A. structB. unionC. enumD. typedef答案:A2. 下列关于链表的描述,错误的是:A. 链表是一种动态数据结构B. 链表的每个节点包含数据和指向下一个节点的指针C. 链表的内存分配必须是连续的D. 链表可以很容易地插入和删除节点答案:C3. 在C语言中,以下哪个函数用于创建一个动态数组?A. mallocB. callocC. reallocD. free答案:B4. 关于栈的描述,以下说法正确的是:A. 栈是一种后进先出(LIFO)的数据结构B. 栈只能进行插入和删除操作C. 栈的插入和删除操作只能从栈底进行D. 栈可以存储任意数量的数据答案:A5. 在C语言中,以下哪个函数用于释放动态分配的内存?A. mallocB. callocC. freeD. realloc答案:C6. 下列关于二叉树的描述,错误的是:A. 二叉树的每个节点最多有两个子节点B. 二叉树的遍历方式有前序、中序和后序C. 二叉搜索树的中序遍历结果是有序的D. 二叉树的深度是指树中节点的最大数量答案:D7. 在C语言中,以下哪个函数用于将一个字符串复制到另一个字符串?A. strcpyB. strncpyC. strcatD. strcmp答案:A8. 关于图的描述,以下说法正确的是:A. 图是一种非线性数据结构B. 图的每个顶点至少有一个边C. 图的遍历可以使用深度优先搜索(DFS)或广度优先搜索(BFS)D. 图的边是无向的答案:A9. 在C语言中,以下哪个关键字用于定义一个指针?A. intB. charC. floatD. *答案:D10. 下列关于哈希表的描述,错误的是:A. 哈希表是一种通过键值对进行存储的数据结构B. 哈希表的查找时间复杂度通常是O(1)C. 哈希表可以解决冲突问题D. 哈希表的键必须是唯一的答案:D二、填空题(每题2分,共20分)1. 在C语言中,定义一个结构体的关键字是________。
数据结构(C语言版)知识点复习资料
数据结构复习资料一、填空题1. 数据结构是一门研究非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和运算等的学科。
2. 数据结构被形式地定义为(D, R),其中D是数据元素的有限集合,R是D上的关系有限集合。
3. 数据结构包括数据的逻辑结构、数据的存储结构和数据的运算这三个方面的内容。
4. 数据结构按逻辑结构可分为两大类,它们分别是线性结构和非线性结构。
5. 线性结构中元素之间存在一对一关系,树形结构中元素之间存在一对多关系,图形结构中元素之间存在多对多关系。
6.在线性结构中,第一个结点没有前驱结点,其余每个结点有且只有 1个前驱结点;最后一个结点没有后续结点,其余每个结点有且只有1个后续结点。
7. 在树形结构中,树根结点没有前驱结点,其余每个结点有且只有 1 个前驱结点;叶子结点没有后续结点,其余每个结点的后续结点数可以任意多个。
8. 在图形结构中,每个结点的前驱结点数和后续结点数可以任意多个。
9.数据的存储结构可用四种基本的存储方法表示,它们分别是顺序、链式、索引和散列。
10. 数据的运算最常用的有5种,它们分别是插入、删除、修改、查找、排序。
11. 一个算法的效率可分为时间效率和空间效率。
12. 在顺序表中插入或删除一个元素,需要平均移动表中一半元素,具体移动的元素个数与表长和该元素在表中的位置有关。
13. 线性表中结点的集合是有限的,结点间的关系是一对一的。
14. 向一个长度为n的向量的第i个元素(1≤i≤n+1)之前插入一个元素时,需向后移动 n-i+1 个元素。
15. 向一个长度为n的向量中删除第i个元素(1≤i≤n)时,需向前移动 n-i 个元素。
16. 在顺序表中访问任意一结点的时间复杂度均为 O(1) ,因此,顺序表也称为随机存取的数据结构。
17. 顺序表中逻辑上相邻的元素的物理位置必定相邻。
单链表中逻辑上相邻的元素的物理位置不一定相邻。
18.在单链表中,除了首元结点外,任一结点的存储位置由其直接前驱结点的链域的值指示。
数据结构(C语言版)期末复习汇总
数据结构(C语言版)期末复习汇总第一章绪论数据结构:是一门研究非数值计算程序设计中的操作对象,以及这些对象之间的关系和操作的学科。
数据结构是一门综合性的专业课程,是一门介于数学、计算机硬件、计算机软件之间的一门核心课程。
是设计和实现编译系统、操作系统、数据库系统及其他系统程序和大型应用程序的基础。
数据:是客观事物的符号表示,是所有能输入到计算机中并被计算机程序处理的符号的总称。
如数学计算中用到的整数和实数,文本编辑中用到的字符串,多媒体程序处理的图形、图像、声音及动画等通过特殊编码定义后的数据。
数据的逻辑结构划分:线、树、图算法的定义及特性算法:是为了解决某类问题而规定的一个有限长的操作序列。
五个特性:有穷性、确定性、可行性、输入、输出评价算法优劣的基本标准(4个):正确性、可读性、健壮性、高效性及低存储量第二章线性表线性表的定义和特点:线性表:由n(n≥0)个数据特性相同的元素构成的有限序列。
线性表中元素个数n(n≥0)定义为线性表的长度,n=0时称为空表。
非空线性表或线性结构,其特点:(1)存在唯一的一个被称作“第一个”的数据元素;(2)存在唯一的一个被称作“最有一个”的数据元素;(3)除第一个之外,结构中的每个数据元素均只有一个前驱;(4)除最后一个之外,结构中的每个数据元素均只有一个后继。
顺序表的插入:n个元素在i位插入,应移动(n-i+1)位元素。
顺序表存储结构的优缺点:优点:逻辑相邻,物理相邻;可随机存取任一元素;存储空间使用紧凑;缺点:插入、删除操作需要移动大量的元素;预先分配空间需按最大空间分配,利用不充分;表容量难以扩充;线性表的应用:一般线性表的合并:★★★算法2.1:LA=(7,5,3,11) LB=(2,6,3)合并后LA=(7,5,3,11,2,6)算法思想:扩大线性表LA,将存在于线性表LB中而不存在于线性表LA中的数据元素插入到线性表LA中去。
只要从线性表LB中依次取得每个数据元素,并依值在线性表LA中进行查访,若不存在,则插入之。
(完整word版)数据结构(C语言)
《数据结构与算法》复习题应用简答题.1.有下列几种用二元组表示的数据结构,画出它们分别对应的逻辑图形表示,并指出它们分别属于何种结构。
(1)A ={D,R},其中:D={a,b,c,d,e,f,g,h},R ={r},r ={<a,b>,<b,c>,〈c,d〉,〈d,e>,〈e,f〉,<f,g>,<g,h〉}(2)B ={D,R},其中:D={a,b,c,d,e,f,g,h},R ={r},r ={<d,b>,〈d,g〉,<d,a〉,<b,c>,<g,e>,<g,h〉,〈e,f〉}(3)C ={D,R},其中:D={1,2,3,4,5,6},R ={r},r ={(1,2),(2,3),(2,4),(3,4),(3,5),(3,6),(4,5),(4,6)}2.简述顺序表和链表存储方式的特点。
答:顺序表的优点是可以随机访问数据元素,缺点是大小固定,不利于增减结点(增减结点操作需要移动元素)。
链表的优点是采用指针方式增减结点,非常方便(只需改变指针指向,不移动结点)。
其缺点是不能进行随机访问,只能顺序访问。
另外,每个结点上增加指针域,造出额外存储空间增大.3.对链表设置头结点的作用是什么?(至少说出两条好处)答:其好处有:(1)对带头结点的链表,在表的任何结点之前插入结点或删除表中任何结点,所要做的都是修改前一个结点的指针域,因为任何元素结点都有前驱结点(若链表没有头结点,则首元素结点没有前驱结点,在其前插入结点和删除该结点时操作复杂些)。
(2)对带头结点的链表,表头指针是指向头结点的非空指针,因此空表与非空表的处理是一样的。
4.对于一个栈,给出输入项A ,B,C 。
如果输入项序列由A ,B,C 组成,试给出全部可能的输出序列。
5.设有4个元素1、2、3、4依次进栈,而栈的操作可随时进行(进出栈可任意交错进行,但要保证进栈次序不破坏1、2、3、4的相对次序),请写出所有不可能的出栈次序和所有可能的出栈次序.6.现有稀疏矩阵A 如图所示,要求画出三元组表示法和十字链表表示法:⎥⎥⎥⎥⎥⎥⎥⎥⎦⎤⎢⎢⎢⎢⎢⎢⎢⎢⎣⎡--000280000000910000000060000003130150220157.设4维数组的4个下标的范围分别为[-1,0],[1,2],[1,3],[-2,-1],请分别按行序和列序列出各元素。
《数据结构(C语言描述)》期末试卷.
专业《数据结构(C 语言描述)》期末试卷 ( — 学年 第 学期)一、填空(10分)1、一个m 阶B-树中,每个结点最少有( ceil(m/2) )个儿子结点,m 阶B+树中每个结点(除根外)最多有( m )个儿子结点.2、n(n>0)个结点构成的二叉树,叶结点最多有( floor((n+1)/2) )个,最少有( 1 )个。
若二叉树有m 个叶结点,则度为2的结点有( m-1 )个。
3、顺序查找方法适用于存储结构为( 顺序表和线性链表 )的线性表,使用折半查找方法的条件是(查找表为顺序存贮的有序表 )4、广义表A=(( ),(a ,(b ,c)),d)的表尾Gettail(A)为( ((a,(b,c)),d) )5、直接插入排序,起泡排序和快速排序三种方法中,( 快速排序 )所需的平均执行时间最小;( 快速排序 )所需附加空间最大。
二、选择(10分)1、倒排文件的主要优点是:( C )A 、便于进行插入和删除B 、便于进行文件的合并C 、能大大提高基于非主关键字数据项的查找速度D 、易于针对主关键字的逆向检索 2 下面程序段的时间复杂性为( C ) y=0;while(n>=(y+1)*(y+1)) { y++; }A 、O(n)B 、O(n 2)C 、 O(sqrt(n))D 、 O(1)3、若从二叉树的任一结点出发到根的路径上所经过的结点序列按其关键字有序,则该二叉树是( C )A 、二叉排序树B 、哈夫曼树C 、堆D 、AVL 树 4、栈和队列都是( B )A 、顺序存储的线性结构B 、限制存取点的线性结构C 、链式存储的线性结构D 、限制存取点的非线性结构5、用顺序查找方法查找长度为n 的线性表时,在等概率情况下的平均查找长度为( D ) A 、n B 、n/2 C 、(n-1)/2 D 、(n+1)/2三、简答(30分)1、已知一棵二叉树的前序扫描序列和中序扫描序列分别为ABCDEFGHIJ 和BCDAFEHJIG ,试给出该二叉树的后序序列并绘出该二叉树对应的森林。
数据结构C语言版期末考试试题(附带复习资料)
“数据结构”期末考试试题一、单选题(每小题2分,共12分)1.在一个单链表HL中,若要向表头插入一个由指针p指向的结点,则执行( )。
A. HL=ps p一>next=HLB. p一>next=HL;HL=p3C. p一>next=Hl;p=HL;D. p一>next=HL一>next;HL一>next=p;2.n个顶点的强连通图中至少含有( )。
A.n—l条有向边B.n条有向边C.n(n—1)/2条有向边D.n(n一1)条有向边3.从一棵二叉搜索树中查找一个元素时,其时间复杂度大致为( )。
A.O(1)B.O(n)C.O(1Ogzn)D.O(n2)4.由权值分别为3,8,6,2,5的叶子结点生成一棵哈夫曼树,它的带权路径长度为( )。
A.24 B.48C. 72 D. 535.当一个作为实际传递的对象占用的存储空间较大并可能需要修改时,应最好把它说明为( )参数,以节省参数值的传输时间和存储参数的空间。
A.整形B.引用型C.指针型D.常值引用型·6.向一个长度为n的顺序表中插人一个新元素的平均时间复杂度为( )。
A.O(n) B.O(1)C.O(n2) D.O(10g2n)二、填空题(每空1分,共28分)1.数据的存储结构被分为——、——、——和——四种。
2.在广义表的存储结构中,单元素结点与表元素结点有一个域对应不同,各自分别为——域和——域。
3.——中缀表达式 3十x*(2.4/5—6)所对应的后缀表达式为————。
4.在一棵高度为h的3叉树中,最多含有——结点。
5.假定一棵二叉树的结点数为18,则它的最小深度为——,最大深度为——·6.在一棵二叉搜索树中,每个分支结点的左子树上所有结点的值一定——该结点的值,右子树上所有结点的值一定——该结点的值。
7.当向一个小根堆插入一个具有最小值的元素时,该元素需要逐层——调整,直到被调整到——位置为止。
数据结构(c语言版)期末考试复习试题
数据结构(c语言版)期末考试复习试题《数据结构与算法》(c语言版)期末考复习题一、选择题。
1.在数据结构中,从逻辑上可以把数据结构分为 C 。
A.动态结构和静态结构B.紧凑结构和非紧凑结构C.线性结构和非线性结构D.部结构和外部结构2.数据结构在计算机存中的表示是指 A 。
A.数据的存储结构B.数据结构C.数据的逻辑结构D.数据元素之间的关系3.在数据结构中,与所使用的计算机无关的是数据的 A 结构。
A.逻辑B.存储C.逻辑和存储D.物理4.在存储数据时,通常不仅要存储各数据元素的值,而且还要存储 C 。
A.数据的处理方法B.数据元素的类型C.数据元素之间的关系D.数据的存储方法5.在决定选取何种存储结构时,一般不考虑 A 。
A.各结点的值如何B.结点个数的多少C.对数据有哪些运算D.所用的编程语言实现这种结构是否方便。
6.以下说确的是 D 。
A.数据项是数据的基本单位B.数据元素是数据的最小单位C.数据结构是带结构的数据项的集合D.一些表面上很不相同的数据可以有相同的逻辑结构7.算法分析的目的是 C ,算法分析的两个主要方面是 A 。
(1)A.找出数据结构的合理性B.研究算法中的输入和输出的关系C.分析算法的效率以求改进C.分析算法的易读性和文档性(2)A.空间复杂度和时间复杂度B.正确性和简明性C.可读性和文档性D.数据复杂性和程序复杂性8.下面程序段的时间复杂度是O(n2) 。
s =0;for( I =0; i<="" p="">for(j=0;j<n;j++)< p="">s +=B[i][j];sum = s ;9.下面程序段的时间复杂度是O(n*m) 。
for( i =0; i<="" p="">for(j=0;j<m;j++)< p="">A[i][j] =0;10.下面程序段的时间复杂度是O(log3n) 。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数据结构(C语言版)期末复习汇总第一章绪论数据结构:是一门研究非数值计算程序设计中的操作对象,以及这些对象之间的关系和操作的学科。
数据结构分为:逻辑结构、物理结构、操作三部分逻辑结构:集合、线性结构、树形结构、图(网)状结构物理结构(存储结构):顺序存储结构、链式存储结构算法:是为了解决某类问题而规定的一个有限长的操作序列。
算法五个特性:有穷性、确定性、可行性、输入、输出评价算法优劣的基本标准(4个):正确性、可读性、健壮性、高效性及低存储量语句频度的计算。
算法的时间复杂度:常见有:O(1),O(n),O(n2),O(log2n),O(nlog2n),O(2n)第二章线性表线性表的定义和特点:线性表:由n(n≥0)个数据特性相同的元素构成的有限序列。
线性表中元素个数n(n≥0)定义为线性表的长度,n=0时称为空表。
非空线性表或线性结构,其特点:(1)存在唯一的一个被称作“第一个”的数据元素;(2)存在唯一的一个被称作“最有一个”的数据元素;(3)除第一个之外,结构中的每个数据元素均只有一个前驱;(4)除最后一个之外,结构中的每个数据元素均只有一个后继。
顺序表的插入:共计n个元素,在第i位插入,应移动(n-i+1)位元素。
顺序表的删除:共计n个元素,删除第i位,应移动(n-i)位元素。
线性表的两种存储方式:顺序存储、链式存储。
顺序存储概念:以一组连续的存储空间存放线性表;优点:逻辑相邻,物理相邻;可随机存取任一元素;存储空间使用紧凑;缺点:插入、删除操作需要移动大量的元素;预先分配空间需按最大空间分配,利用不充分;表容量难以扩充;操作:查找、插入、删除等查找:ListSearch(SqlList L,ElemType x,int n){int i;for (i=0;i<n;i++){if(x==L .elem[i]) break; }if(i==n) return(0);elsereturn(i+1);}//ListSearch删除:ListDelete(SqlList &L,int i,ElemType &e){if (i<1||i>L.length)return ERROR; //i值不合法p=&(L.elem[i-1]); //p为被删除元素的位置e=*p; //被删除元素的值赋给eq=L.elem+L.length-1 //表尾元素的位置for(++p;p<=q;++p)*(p-1)=*p; //被删除元素之后的元素左移--L.length; //表长减1return e;}//ListDelete插入:ListInsert(SqlList &L, int i, ElemType e){ if (i<1||i>L.length+1)return ERROR; //i值不合法。
if (L.length>=Listsize) //当前存储空间已满,增加分配{ newbase=(ElemType*)realloc(L.elem,(L.Listsize+LISTINCREMENT)*sizeof(ElemType));//realloc(void * p,unsigned size)该函数将p所指出的已分配内存区的大小改为size, size可以比原来分配的空间大或小//If (!newbase) exit(OVERFLOW); //存储分配失败L.elem=newbase; //新基址L.Listsize+=LISTINCREMENT; );//增加存储容量}q=&(L.elem[i-1]); //q为插入位置for(p=&L. elem[L.length-1];p>=q;- - p) *(p+1)=*p; //插入位置之后的元素右移*q=e; //插入e++L.length; //表长增加1return OK;}//ListInsert单链表——线性表的链式存储结构之一概念:线性链表又称单链表,结点:数据域,指针域;头指针,头结点。
单链表特点:用指针表示数据之间的逻辑关系(逻辑相邻的元素物理位置不一定相邻)。
它是一种动态结构,不需预先分配空间;不足:指针占用额外存储空间;不能随机存取,查找速度慢。
节点定义:“数据+ 指针”typedef struct LNode { DataType data; struct LNode *next; } LNode, *LinkList;单链表的插入:元素x 结点应预先生成: S=(test*)malloc(m); S->data=x;S->next=p->next p->next=s 单链表删除:q = p->next; //保存b 的指针,靠它才能指向c p->next=q->next; //a 、c 两结点相连free(q) ; //删除b 结点,彻底释放线性表的应用:(1):用单链表结构存放26个英文字母组成的线性表(a ,b ,c ,…,z ),请写出C 语言程序。
#include<stdio.h> #include<stdlib.h>/*将全局变量及函数提前说明:*/ typedef struct liu{ char data;struct liu *next; }test;test *p,*q,*head; //一般需要3个指针变量 int n ; // 数据元素的个数int m=sizeof(test); /*结构类型定义好之后,每个变量的长度就固定了,m 求一次即可*/void build( ) //字母链表的生成。
要一个一个链入 {int i;p=(test*)malloc(m); //m=sizeof(test) 前面已求出head =p; //头指针,没有头结点 for(i=1;i<26;i++)//因尾结点要特殊处理,故i≠26 {p->data=i+‘a’-1; // 第一个结点值为字符ap->next=(test*)malloc(m); //为后继结点开新空间!p=p->next;//让指针变量P改为指向后继结点}p->data=i+‘a’-1; //最后一个元素要单独处理p->next=NULL ; //单链表尾结点的指针域要置空!}void display()/*字母链表的输出*/{ p=head;while (p) /* 只要没到最后一个元素,就不停地“顺藤摸瓜”输出*/{ printf("%c",p->data);p=p->next;}}(2)线性表的合并:(顺序储存结构)算法2.1:LA=(7,5,3,11) LB=(2,6,3)合并后LA=(7,5,3,11,2,6)算法思想:扩大线性表LA,将存在于线性表LB中而不存在于线性表LA中的数据元素插入到线性表LA中去。
只要从线性表LB中依次取得每个数据元素,并依值在线性表LA中进行查访,若不存在,则插入之。
void union(List &LA, List &LB)//主函数,参数为两个线性表{La_len = ListLength(LA); // 求得线性表LA 的长度while (!ListEmpty(LB)) // 依次处理LB 中元素直至LB 为空表止{ListDelete(LB,1,e); // 从LB 中删除第1个数据元素并赋给eif (!LocateElem(LA,e,equal( ))ListInsert(LA,++La_len,e);// 当LA中不存在和 e 值相同的数据元素时进行插入} //DestroyList(LB);// 销毁线性表LB} // union第三章栈和队列栈的类型定义:栈(Stack)是限制在表的一端进行插入和删除运算的线性表,通常称插入、删除的这一端为栈顶(Top),另一端为栈底(Bottom)。
当表中没有元素时称为空栈。
假设栈S=(a1,a2,a3,…an),则a1称为栈底元素,an为栈顶元素。
栈中元素按a1,a2,a3,…an的次序进栈,退栈的第一个元素应为栈顶元素。
即,栈的修改是按后进先出的原则进行的。
因此,栈称为后进先出表(LIFO)。
栈的进栈(push)操作:Status Push(Stack &S, SElemType e){//插入元素e为新的栈顶元素if (S.top-S.bottom>=S.stacksize){//栈满,追加存储空间S.bottom=(SElemType)realloc(S.bottom,(S.stacksize+STACKINCREMENT)*sizeof(ElemType)); if (!S.bottom) exit(overflow); //存储分配失败S.top=S.bottom+S.stacksize; //设置新栈的栈顶S.stacksize+=STACKINCREMENT;} //设置新栈的大小*S.top++=e; //先赋值,后加1Return OK;}//Push出栈(pop)操作:Status Pop(Stack &S, SElemType &e){//若栈不空,则删除S的栈顶元素,用e返回其值,并返回OK;否则返回ERRORif (S.top==S.bottom) Return ERROR;S.top-- ; e=*S. top ;Return OK;}//Pop进栈、出栈顺序:对于一个栈,给出输入项A、B、C,如果输入项序列由ABC组成,试给出所有可能的输出序列。
A进A出B进B出C进C出ABCA进A出B进C进C出B出ACBA进B进B出A出C进C出BACA进B进B出C进C出A出BCAA进B进C进C出B出A出CBA不可能产生输出序列CAB栈的应用:数值转换算法思想:首先将按照上述计算过程中得到的八进制数的各位依次进栈,然后将栈中的八进制数依次出栈输出,输出结果就是该是十进制数转换得到的八进制数。
N=(N div d)×d + N mod d (其中:div 为整除运算,mod 为求余运算)例如(1348)10=(2504)8,其运算过程如下:N N div 8 N mod 81348 168 4168 21 021 2 52 0 2算法:void conversion(int n , int d) /*将十进制整数N转换为d(2或8)进制数*/ { SqStack S ; int k, *e ; //建立堆栈SS=Init_Stack(); //堆栈S初始化while (n>0) { k=n%d ; push(S , k) ; n=n/d ; }/* 求出所有的余数,进栈*/while (S.top!=0) /* 栈不空时出栈,输出*/{ pop(S, e) ;printf(“%1d” , *e) ;}}队列的类型定义:定义:队列是限定只能在表的一端进行插入,在表的另一端进行删除的线性表 队尾(rear):允许插入的一端 队头(front):允许删除的一端 队列特点:先进先出 ( FIFO ) 队列储存结构:顺序队、链队 顺序队列操作: 插入:insertseq(Sequeue *q,Elemtype x){/*将元素x 插入到队列q 中,作为q 的新队尾,即入队操作*/ if (q->rear>Maxsize-1) return FALSE; /*队列满*/ else { q->data[q->rear]=x; //先插入数据 q->rear++; //再移动指针 return TRUE; }}//insertseq 删除:Elemtype deleteseq(Sequeue *q){/*若队列q 不为空,则删除队头元素,即出队列操作*/Elemtype x; //定义数据元素变量,存放删除元素 if (q->rear= =q->front) return NULL; //队列空 else { x=q->data[q->front]; //先删除数据 q->front++; //再移动指针 return x; }}//deleteseq循环顺序队插入、删除分析:(c) BC 入队front(b)A 入队frontfront(a) 初始状态 front=rear=0(d) A 出队(f) DEFG 入队第四章 串串的类型定义:串是字符串的简称。