%|"O;x(_:
L7n4b3o7C7Q1.5线性链表#t)A&p"C7P$u%r
数据结构中的每一个结点对应于一个存储单元,这种存储单元称为存储结点,简称结点。
6w:
}#|!
`.f1P
结点由两部分组成:
(1)用于存储数据元素值,称为数据域;
(2)用于存放指针,称为指针域,0|6T!
v%r:
@"g0U
在链式存储结构中,存储数据结构的存储空间可以不连续,各数据结点的存储顺序与数据元素之间的逻辑关系可以不一致,而数据元素之间的逻辑关系是由指针域来确定的。
1b;U*W6t }%O3M$D%?
!
C#s#e
链式存储方式即可用于表示线性结构,也可用于表示非线性结构。
+z4q*G/g8i"m%O'^线性链表的基本运算:
查找、插入、删除。
4O-|1]*m&@ v5M%{*|+k1.6树与二叉树6f)w(].^,z-I,u
树是一种简单的非线性结构,所有元素之间具有明显的层次特性。
2L9O0{%L9K3V T&q在树结构中,没有前件的结点只有一个,称为树的根结点,简称树的根。
每一个结点可以有多个后件,称为该结点的子结点。
没有后件的结点称为叶子结点。
/K,D5{9\(N9b在树结构中,一个结点所拥有的后件的个数称为该结点的度,所有结点中最大的度称为树的度。
树的最大层次称为树的深度。
0z(H4V7J"n c7{;k6k*[二叉树的特点:
(1)非空二叉树只有一个根结点;
(2)每一个结点最多有两棵子树,且分别称为该结点的左子树与右子树。
J6c8U"e;j,H+z二叉树的基本性质:
必考的题目
:
^5t6D'C6B6U,m'T&a1O+m
(1)在二叉树的第k层上,最多有2k-1(k≥1)个结点;,@.e5B6M-M3t)O2e8t&^
(2)深度为m的二叉树最多有2m-1个结点;
;N5k4R1r&[2j(3)度为0的结点(即叶子结点)总是比度为2的结点多一个;
0S4J5P'U&t(w(4)二叉树中n=n0+n1+n2
满二叉树是指除最后一层外,每一层上的所有结点有两个子结点,则k层上有2k-1个结点深度为m的满二叉树有2m-1个结点。
;t$u2c*m'c&j)h;a,H5\5o完全二叉树是指除最后一层外,每一层上的结点数均达到最大值,在最后一层上只缺少右边的若干结点。
%B7a)R-b4I1M
二叉树存储结构采用链式存储结构,对于满二叉树与完全二叉树可以按层序进行顺序存储。
.F1{+E1E'^,E4o+R"W二叉树的遍历:
(一般画个图要你把顺序写出来)%~"c!
i9B%@0Q+S
(1)前序遍历(DLR),首先访问根结点,然后遍历左子树,最后遍历右子树;$u/q4a(g1R,k
(2)中序遍历(LDR),首先遍历左子树,然后访问根结点,最后遍历右子树;9g0h!
Y,V0\+_4H;~
(3)后序遍历(LRD)首先遍历左子树,然后访问遍历右子树,最后访问根结点。
$M%w#b5g8g9e;s*Y
1.7查找技术#[(i.G%^5u9v(k.F.q
顺序查找的使用情况:
*o)j,D;m1o,U*x长度为n的线性表,找出一个数据,最差的情况为比较n次。
长度为n的线性表,找出一个最大数据,最差的情况为比较n-1次。
#\2f6P;L$n"e:
u;]"o
二分法查找只适用于顺序存储的有序表,
二分查找:
对于长度为n的有序线性表,最坏情况只需比较log2n次。
;L3\8^)E6J6G
1.8排序技术
0\,x$A/M"z+C-L;L排序是指将一个无序序列整理成按值非递减顺序排列的有序序列。
1k"q+G'}%_)A9^(f
交换类排序法:
(1)冒泡排序法,需要比较的次数为n(n-1)/2;
(2)快速排序法,需要比较的次数为n(n-1)/2;。
&z)@,H6~&z!
j插入类排序法:
(1)简单插入排序法,最坏情况需要n(n-1)/2次比较;
(2)希尔排序法,最坏情况需要O(n1.5)次比较。
6D(W-r1q$R%p4Z&[选择类排序法:
(1)简单选择排序法,最坏情况需要n(n-1)/2次比较;
(2)堆排序法,最坏情况需要O(nlog2n)次比较。
第二章程序设计基础
#f*Y-Y)F5v,_+@+n2.1程序设计设计方法和风格
)K9c&X)O$J9[注释分序言性注释和功能性注释,语句结构清晰第一、效率第二。
不要弄反了。
程序一定要求具有易读性,可读性较好。
程序设计方法有两种,结构化程序设计和面向对象程序设计。
1q%],M#G2f.v(C1Y2.2结构化程序设计
7R2d9A8w6S&X3d!
~结构化程序设计方法的四条原则是:
考试重点都要背下来
1.自顶向下;2.逐步求精;3.模块化;4.限制使用goto语句。
注意,这四个特点中,最重要的是模块化。
结构化程序的基本结构和特点:
5s-K'O8k)Q%c){.D)w
(1)顺序结构:
一种简单的程序设计,最基本、最常用的结构;
1G:
p:
Y9I)F2O+}-S
(2)选择结构:
又称分支结构,包括简单选择和多分支选择结构,;@2T'@!
C4p3k w1X*t;r#q.R
(3)循环结构:
可根据给定条件,判断是否需要重复执行某一相同程序段。
1Q3m0^6]#L6~
2.3面向对象的程序设计
/X6D&c8t!
D)~+{;K.]+p"Y面向对象的程序设计:
以对象为核心。
面向对象具备哪些基本概念:
对象、类和实例、消息、继承、多态性、
面向对象方法的优点:
3X3P5L$C#x/~1V0C7C
(1)与人类习惯的思维方法一致;"g,{5M v.g:
k$E't2D
(2)稳定性好;"K"_'i9W4U:
v8K#f+B-\ ?
(3)可重用性好;
7t)B)]"z8?
7L-[(4)易于开发大型软件产品;*a6^,`!
[*V&g7a!
_$\.s2p
(5)可维护性好。
7v9p)l:
Z [%p9m/h.I7L,n3n对象是面向对象方法中最基本的概念,对象是实体的抽象。
c!
R2g;\,Q&f0u)|
面向对象的程序设计方法中的对象是系统中用来描述客观事物的一个实体,是构成系统的一个基本单位,由一组表示其静态特征的属性和它可执行的一组操作组成。
/['r/q9o5H/X(].S0e.g#~6a属性即对象所包含的信息,操作描述了对象执行的功能,操作也称为方法或服务。
5Q:
J+P6d ^
对象的基本特点:
'\#t"k"e7r'H/H+G0h
(1)标识惟一性; {#B*U,y)M8P.\7^$y
(2)分类性;
(O1U(G.@(M p g,W+_8_1J(3)多态性;重点([*}*g#V*?
)P
(4)封装性;重点-[(r4_;y7r9J:
P1T4J o
(5)模块独立性好。
;I-e4l5U0~+G8S.?
1]类是指具有共同属性、共同方法的对象的集合。
类是对象的抽象,对象是对应类的一个实例。
:
l6?
3D2m!
I*\"d消息是一个实例与另一个实例之间传递的信息。
)K/m"N-M"Y0c$l7v4l消息的组成包括:
(1)接收消息的对象的名称;
(2)消息标识符,也称消息名;(3)零个或多个参数。
继承是指能够直接获得已有的性质和特征,而不必重复定义他们。
t0B:
Y w(O*v.R7b6E(N)S%G+J继承分单继承和多重继承。
对象也可以没有继承。
1、单继承指一个类只允许有一个父类,
2、多重继承指一个类允许有多个父类。
#Y'f-A+] O4K&M
多态性是指同样的消息被不同的对象接受时可导致完全不同的行动的现象
第三章软件工程基础
7s!
v;j6L;\.G&?
;l.i3.1软件工程基本概念
$S/H q/^"x7e3D4i1V v:
k计算机软件是包括程序、数据及相关文档的完整集合。
.w.E6M:
s'U:
_+L+O5S,K-\;o
软件的特点包括:
!
T)h)^ ?
/x6l#u6a H/@'g
(1)软件是一种逻辑实体;8U%A @,M4p0_-v.W
(2)软件的生产与硬件不同,它没有明显的制作过程;6P,L8]0h7p+d(k
(3)软件在运行、使用期间不存在磨损、老化问题;
7y!
P0g'B5l6\&w6p:
S.i(4)软件的开发、运行对计算机系统具有依赖性,
(5)软件复杂性高,成本昂贵;
3b-t(J'O4w"X%q.@!
o&]:
a(6)软件开发涉及诸多的社会因素。
1w:
k2F+g7k6M软件按功能分为应用软件、系统软件、支撑软件(或工具软件)。
1、数据库管理系统是系统软件。
2、教务处管理系统是应用软件。
6W#^9G/g9G7B7E软件危机主要表现在成本、质量、生产率等问题。
'~9o+W;i9s$r-~3w8s,Q软件工程是应用于计算机软件的定义、开发和维护的一整套方法、工具、文档、实践标准和工序。
2P%F.U*|$N8O){)^"Z软件工程包括3个要素:
方法、工具、过程。
#~&e,X2N+l8q3G
方法:
完成软件工程项目的技术手段。
工具:
支持软件的开发、管理、文档生成。
过程:
支持软件开发的各个环节的控制、管理。
软件工程过程是把软件转化为输出的一组彼此相关的资源和活动,包含4种基本活动:
f+h%b.x3A6g(^6e
(1)P——软件规格说明;
(2)D——软件开发;(3)C——软件确认;(4)A——软件演进。
-Y.}5I6E5w2T
软件生命周期:
软件产品从提出、实现、使用维护到停止使用退役的过程。
.Z3z d%?
a;C8b
软件生命周期三个阶段:
软件定义、软件开发、运行维护,主要活动阶段是:
7o'k-v-_'\(k1I;f.Q;E8s
需求分析是定义阶段。
详细设计和概要设计是开发阶段。
o/d!
T"n1R,[#B0I1X!
P
软件工程的目标和与原则:
1E.H4H1B5H1T.E(L目标:
在给定成本、进度的前提下,开发出具有有效性、可靠性、可理解性、可维护性、可重用性、可适应性、可移植性、可追踪性和可互操作性且满足用户需求的产品。
"@#T#w.u)~.N1t b/F(O
基本目标:
付出较低的开发成本;达到要求的软件功能;取得较好的软件性能;开发软件易于移植;需要较低的费用;能按时完成开发,及时交付使用。
(C!
C;?
+}'D
基本原则:
抽象、信息隐蔽、模块化、局部化、确定性、一致性、完备性和可验证性。
!
~%v,H'k)V-^ J9^软件工程的理论和技术性研究的内容主要包括:
软件开发技术和软件工程管理。
"Z7_%n5R7L!
h.B4G0l软件开发技术包括:
软件开发方法学、开发过程、开发工具和软件工程环境。
/S*|*T6S+v(Z
软件工程管理包括:
软件管理学、软件工程经济学、软件心理学等内容。
0A/]4t Q;u&\)T
软件管理学包括人员组织、进度安排、质量保证、配置管理、项目计划等。
6s+b.r%l4b2G's:
L软件工程原则包括抽象、信息隐蔽、模块化、局部化、确定性、一致性、完备性和可验证性。
"q+X8B8v'A&G3.2结构化分析方法
9t.O7H4l0I8^#Z'm结构化方法的核心和基础是结构化程序设计理论。
-]9E7o,R8p2@)E5Y!
`需求分析方法有
(1)结构化需求分析方法;
(2)面向对象的分析的方法。
9Y.D9G:
t l5A,B
需求分析阶段工作4个方面:
1、需求获取 2、需求分析 3、编写需求规格说明书(重点) 4、需求评审
从需求分析建立的模型的特性来分:
静态分析和动态分析。
)w%j&w5b&Y2Z2E'U2P结构化分析方法的实质:
面向数据流,自顶向下,逐层分解,建立系统的处理流程,以数据流图和数据字典为主要工具,建立系统的逻辑模型。
$X%z,m)J9G:
^%p结构化分析的常用工具:
*l7l*y5G4A-K+t"m0{5_#`#M:
Q
(1)数据流图;
(2)数据字典;(3)判定树;(4)判定表。
8x#s;c+`)K*i&Z(v#]:
a数据流图:
描述数据处理过程的工具,是需求理解的逻辑模型的图形表示,它直接支持系统功能
建模。
+U3F%a6D._(T数据字典:
对所有与系统相关的数据元素的一个有组织的列表,以及精确的、严格的定义,使得
用户和系统分析员对于输入、输出、存储成分和中间计算结果有共同的理解。
数据字典是结构化分析的核心。
;I9`1a,s;Z)Q7x'^8E软件需求规格说明书的特点:
(核心的是无歧义性))m2A3n'_:
[.K+i:
y
(1)正确性;
(2)无岐义性;(3)完整性;(4)可验证性;
(5)一致性;(6)可理解性;(7)可追踪性。
;`2D,I9u&z/t#S(V
3.3结构化设计方法:
D5l.D%p/L#D
软件设计的基本目标是用比较抽象概括的方式确定目标系统如何完成预定的任务,
软件设计是确定系统的物理模型。
4e2v7a;V"v t R.^
软件设计是开发阶段最重要的步骤,是将需求准确地转化为完整的软件产品或系统的唯一途径。
:
e%o9h6A;F*}(D#H
从技术观点来看,软件设计包括软件结构设计、数据设计、接口设计、过程设计。
。
:
}5Z6~+^)^从工程管理角度来看:
概要设计和详细设计。
(| R2N$X#u5r,t
软件设计的一般过程:
软件设计是一个迭代的过程;先进行高层次的结构设计;后进行低层次的过程设计;穿插进行数据设计和接口设计。
*v*g%Y1H5p;N衡量软件模块独立性使用耦合性和内聚性两个定性的度量标准。
耦合性:
对一个软件结构中不同模块之间互连程度的度量。
内聚性:
一个模块内部各个元素间彼此结合的紧密程度的度量。
"L'P!
x7w$}0v1v.Y在程序结构中各模块的内聚性越强,则耦合性越弱。
优秀软件应高内聚,低耦合。
+x:
s!
V%S(C%H%Q1Z,t软件概要设计的基本任务是:
$W+h-F {&D%v4~"o
(1)设计软件系统结构;
(2)数据结构及数据库设计;2s+M9p4J3T1P)]-m"]
(3)编写概要设计文档;(4)概要设计文档评审。
;T%X#v&Q)^3d4q6^2o._1n模块用一个矩形表示,箭头表示模块间的调用关系。
.T9x#z.S"V(X!
Z;D+`在结构图中还可以用带注释的箭头表示模块调用过程中来回传递的信息。
还可用带实心圆的箭头表示传递的是控制信息,空心圆箭心表示传递的是数据。
3m0}!
g9q5m6L;{;{结构图的基本形式:
基本形式、顺序形式、重复形式、选择形式。
&H9S,Z9a.I;C#L;\结构图有四种模块类型:
传入模块、传出模块、变换模块和协调模块。
8c1X!
a2\;k,m*B
典型的数据流类型有两种:
变换型和事务型。
3_;D;r5q#y8f:
y#M变换型系统结构图由输入、中心变换、输出三部分组成。
&R u6}7K0V5_;V
事务型数据流的特点是:
接受一项事务,根据事务处理的特点和性质,选择分派一个适当的处理单元,然后给出结果。
1Z1{5~'c#T6`详细设计:
是为软件结构图中的每一个模块确定实现算法和局部数据结构,用某种选定的表达工具表示算法和数据结构的细节。
;a4?
4F1h(y$K+f'U9{
常见的过程设计工具有:
考试重点
1、图形工具(程序流程图)、2、表格工具(判定表)、3、语言工具(PDL)。
程序流程图是考试重点,其中->箭头表示控制流,<>菱形表示逻辑条件。
"r8R+X1F)n!
z2@1s$s
3.4软件测试7U5h#f2J6o3W1a!
K*U)W
软件测试定义:
使用人工或自动手段来运行或测定某个系统的过程,其目的在于检验它是否满足规定的需求或是弄清预期结果与实际结果之间的差别。
)y+G/[3h5q6d3I3D'\9m软件测试的目的:
发现错误而执行程序的过程。
.X9t/g!
E6K;e-B&S;w&o;g(r
软件测试方法:
静态测试和动态测试。
9|6i6b7M.Z:
]-D静态测试:
包括代码检查、静态结构分析、代码质量度量。
不实际运行软件,主要通过人工进行。
(O/d(P/A3J ^动态测试:
是基本计算机的测试,主要包括白盒测试方法和黑盒测试方法。
1Q9u6G5i3o2b)W1N白盒测试:
在程序内部进行,主要用于完成软件内部CAO作的验证。
主要方法有逻辑覆盖、基
本基路径测试。
%C%}/S$R2h5s-^%[
黑盒测试:
主要诊断功能不对或遗漏、界面错误、数据结构或外部数据库访问错误、性能错误、
初始化和终止条件错,用于软件确认。
白盒主要方法:
1、逻辑覆盖测试2、基本路径测试。
黑盒主要方法:
1等价类划分法、2边界值分析法、3错