# 学期2024-2025-1 学号20241416《计算机基础与程序设计》第7周学习总结
这个作业属于哪个课程 https://edu.cnblogs.com/campus/besti/2024-2025-1-CFAP/
这个作业要求在哪里 https://www.cnblogs.com/rocedu/p/9577842.html#WEEK07
这个作业的目标 数组与链表、基于数组和基于链表实现数据结构、无序表
作业正文 https://www.cnblogs.com/rockytyh/p/18538402
教材学习内容总结
数组与链表
数组:是一种连续存储的数据结构,具有固定大小,元素在内存中连续排列。通过索引可以快速访问元素,但插入和删除操作可能比较复杂,因为需要移动大量元素(尤其是在数组中间插入或删除)。例如,若要在一个已排序的数组中插入一个新元素,可能需要将插入位置之后的所有元素向后移动一位。
链表:由一系列节点组成,每个节点包含数据和指向下一个节点的指针。链表的大小可以动态变化,插入和删除操作相对容易,只需修改相关节点的指针即可。但查找元素通常需要遍历链表,时间复杂度较高。
基于数组与链表实现数据结构
基于数组实现:可以用于实现栈、队列等数据结构。例如,栈可以用数组来实现,通过一个指针指向栈顶元素,入栈和出栈操作可以通过修改指针和相应的数组元素来完成。
基于链表实现:同样可用于实现栈、队列,而且在实现更复杂的数据结构如树、图时也有广泛应用。例如,二叉树可以用链表来表示,每个节点包含数据、左子节点指针和右子节点指针。
无序表与有序表
无序表:数据元素没有特定顺序,在实现上可以使用数组或链表。插入操作相对简单,只需将元素添加到合适位置(如链表末尾或数组的下一个可用位置)。查找和删除操作可能需要遍历整个列表。
有序表:数据元素按照特定的顺序(如升序或降序)排列。插入操作需要在合适的位置插入元素以保持顺序,可能涉及到元素的移动(数组情况)或指针修改(链表情况)。查找操作可以利用顺序性更快地找到目标元素(如二分查找法可用于有序数组)。
教材学习中的问题和解决过程
问题1:在基于链表实现栈的数据结构中,入栈和出栈操作的时间复杂度是多少?
答案1:在基于链表实现栈时,入栈操作只需要在链表头部插入一个节点,时间复杂度为 O(1)。出栈操作也只需要删除链表头部的节点,同样时间复杂度为 O(1)。
因为链表的插入和删除操作在头部进行时,只需要修改指针,不需要移动大量元素,所以时间复杂度较低。
问题2:在学习数据结构的具体实现,如链表实现列表或者二叉树的节点结构时,难以理解代码中的指针操作或者节点之间的关联方式。
答案2:编写简单的函数,分别使用值传递和引用传递的方式传递参数,在函数内部对形参进行操作,然后观察实参的变化情况。通过详细分析代码执行过程中的变量值和内存地址变化来理解参数传递机制。