课程名称 算法设计与分析基础 nEu:& 4
英文名称 The Fundation of Design and Analysis of Algorithms R/x3+_.f
课程编号 不填 总学时 60 学 分 不填 !*Is0``
预修课程 数 据 结 构 开课学期 不填 ;*Vnwt A
大纲撰写人 顾 乃 杰 ;Tr,BfV|Bf
一、教学目标和基本要求 =s":Mx,o
目标:本课程是高等学校计算机系各专业的基础课, 其要求是使学生了解和掌握算法基础这门课程的基本内容, 知道算法设计的基本方法和技术, 学会算法性能分析中的具体方法和技巧, 为计算机应用和科学研究工作中有效求解问题, 以及为今后进一步学习打下基础。 dJ
I }uQ
基本要求:使学生能够从的运算三个方面去掌握各种数据结构的特性, 对算法的时、空复杂性有一定的分析能力,使之能够针对具体的应用问题, 选择合适的数据结构及设计结构清晰、正确有效的算法解决之。 %B\x
%e;P
二、课程简介 qr4 lr!#t
本课程系统而全面地介绍了算法设计的基本策略和方法, 如:分治法、贪心法、动态规划、回溯法、分枝-限界等等, 并从解决大量计算机科学和应用中出现的问题出发, 描述了应用这些策略和方法而设计有效算法的过程, 并且给出了若于精典算法, 同时,对通过对这些典型算法的时间和空间复杂度的分析,逐步介绍了算法分析的方法和步骤, 以及提高算法性能的技巧, 着重强调了算法优化的思想。 J@:Q(
三、教学重点、难点 ~D3S01ecM
重点: 算法设计的基本思想和策略, 算法优化的技巧, 算法性能分析的方法; Hc'Pp{| X
难点: 将算法优化的思想贯穿在设计过程中, 算法平均性能的分析技巧。 JWd[zJ[
0Qa0
四、教材名称及主要参考书 \4wMv[;7
参考书:《计算机算法基础》,邹海明,余祥宣, 华中理工大学出版社 DAb/B
《计算机算法导引》,卢开澄 编著, 清华大学出版社 I+H~ 5zq.
N-QS/*C.~
B zS4:e<
五、课程章节主要内容及学时分配 e:Y+-C5
:W, S
第一章 绪 论 (2 学时) R ?iCJ5 m
第一节 基本概念 +Mq\3
第二节 算法的设计和性能度量 N\*oL*[j
第三节 标准记号与常用函数和公式 ,Tr&`2w
第二章 分治与递归策略 (5 学时) nSyLt6zn\
第一节 二分检索 0 YFXF
第二节 矩阵的快速乘法 lo>9 \ Po
第三节 快速傅里叶变换(FFT) b_RO%L:"yL
第四节 广义表及递归算法 u!|_bI3
第三章 排序与选择 (5 学时) aI&~aezmN
第一节 简单排序和SHELL排序 ybiTWM
第二节 选择排序和堆排序 L"
ejA
第三节 快速排序和归并排序 )).=MTk
第四节 选择问题 YCiG~y/~
第五节 桶排序和基数排序 pYQSn.`V~
第四章 贪心策略 (4学时) +@?Q "B5u}
第一节 文件存储 \)/qCeiZ
第二节 背包问题 UCcr>
第三节 有限期的作业调度问题 +pqbl*W;1
第五章 串匹配 (4学时) "qq$i35x
第一节 一般算法 ]7_>l
>
第二节 Rabin-Karp算法 }PK4
KRn
第三节 Knuth-Morris-Pratt算法 &m