第一章:绪论
1、计算机科技的两大支柱 1、数据结构 2、算法
· 程序= 数据结构+ 算法
2、数据结构定义: 是一门研究非数值计算的程序设计问题中计算机的操作对
象以及它们之间的关系和操作等等的学科。
数据(Data):是对信息的一种符号表示。在计算机科学中是指所有能输入到计算机
中并被计算机程序处理的符号的总称。
数据元素(Data Element):是数据的基本单位,在计算机程序中通常作为一个整体
进行考虑和处理。
一个数据元素可由若干个数据项组成。数据项是数据的不可分割的最小单
位。
数据结构(Data Structure):是相互之间存在一种或多种特定关系的数据元素的集
合。
3、数据结构主要指逻辑结构和物理结构
数据之间的相互关系称为逻辑结构。通常分为四类基本结构:
集合结构中的数据元素除了同属于一种类型外,别无其它关系。
线性结构结构中的数据元素之间存在一对一的关系。
树型结构结构中的数据元素之间存在一对多的关系。
图状结构或网状结构结构中的数据元素之间存在多对多的关系。
4、数据结构在计算机中有两种不同的表示方法:
顺序存储结构:用数据元素在存储器中的相对位置来表示数据元素之间的逻辑关
系。
链式存储结构:在每一个数据元素中增加一个存放地址的指针,用此指针来表示
数据元素之间的逻辑关系。
5、数据对象:某种数据类型元素的集合。
例:整数的数据对象是{…-3,-2,-1,0,1,2,3,…}
英文字符类型的数据对象是{A,B,C,D,E,F,…}
数据类型:在一种程序设计语言中,变量所具有的数据种类。
6、数据结构的三个方面:
7、算法用抽象的语言描述解决特定问题的每一步的操作。程序是计算机能理解
和执行的指令序列。一个程序实现一个算法。算法和程序的区别是算法的执行
是有穷的,而程序的执行可以是无限的。
8、时间复杂度:
1 / 1
9、1、什么是集合
通常情况下,把具有相同性质的一类东西,汇聚成一个整体,就可以称为集合。
比如,用 Java 编程的所有程序员,全体中国人等。
2、什么是集合框架
集合框架是为表示和操作集合而规定的一种统一的标准的体系结构。任何集合
框架都包含三大块内容:对外的接口、接口的实现和对集合运算的算法。
3、集合框架对我们编程有何助益:它减少了程序设计的辛劳、它提高了程序速
度和质量。
10、Collection 接口是一组允许重复的对象。
Set 接口继承 Collection,但不允许重复,使用自己内部的一个排列机制。
List 接口继承 Collection,允许重复,以元素安插的次序来放置元素,不会重新
排列。
Map 接口是一组成对的键-值对象,即所持有的是 key-value pairs。Map 中不能
有重复的 key。拥有自己的内部排列机制。
2 / 2
容器中的元素类型都为 Object。从容器取得元素时,必须把它转换成原来的类型。
第四章:递归
1、递归的定义若一个对象部分地包含它自己, 或用它自己给自己定义, 则称
这个对象是递归的;若一个过程直接地或间接地调用自己, 则称这个过程是递
归的过程。
第五章:数组列表
1、线性表是由n(n≥0)个相同类型的数据元素a1,a2,…,an组成的有限序列,
记作:LinearList={a1,a2,…,an}
其中,n 表示线性表的元素个数,称为线性表的长度。
2、线性表的顺序存储结构:是用一组连续的存储单元顺序存放线性表的数据元
素,数据元素在内存的物理存储次序与它们在线性表中的逻辑次序是一致的,
即数据元素 ai 与其前驱数据元素 ai-1 及后继数据元素 ai+1 的位置相邻。
5、为什么需要串行化:希望 ArrayList 对象保存到文件中,以便于恢复使用。
6、如何实现类可串行化:见练习
package ;
public interface Serializable {//标记接口
}
7、迭代器是允许以一致的方式对集合对象的元素进行访问的对象。
迭代器对象一旦发现另一个对象在结构上修改这一集合,就马上会报错。这是因
为一旦你开始对一个 ArrayList 对象进行迭代,就不能再修改这个 ArrayList 完
整性。因此弹出 ConcurrentModificationException
1. 掌握 Collection 接口含义及方法
2. 掌握 Collection 接口与 List 接口的关系:见练习本
3 / 3
3. 掌握 Array
java数据结构 来自淘豆网www.taodocs.com转载请标明出处.