编辑推荐
暂无
内容简介
本书以知识体系结构和思维方式两个方面作为主线,分成四大篇14章介绍了基本编程能力的实验(基础)、线性数据结构的编程实验(线性表)、层次类非线性表的编程实验(树)以及群聚类非线性表的编程实验(图),并将“排序”和“搜索”的内容融合到相关章节中。每章节由实验范例和题库两个部分组成,试题全部选自ACM国际大学生程序设计竞赛和其他程序设计竞赛,共204题,并给出了试题来源和在线测试地址。每个实验范例不仅有详尽的知识要点阐述和试题解析,而且列出了写有详细注释的参考程序;而题库中的所有试题无论难易,都有清晰的提示。该书还附带了存储所有试题的英文原版描述和大部分试题的测试数据等资料的光盘。
本书的实验范例部分可以作为程序设计语言和数据结构的实验教材,供大学教学使用;题库部分则可以作为计算机专业学生的研修资料和程序设计竞赛的培训教材。
作者简介
吴永辉 博士,复旦大学计算机科学与工程系副教授,ACM-ICPC中国赛区指导委员会(ACM-ICPC CouncilChina)成员,复旦大学ACM程序设计竞赛队教练。作者自2001年起连续带队进入ACM-ICPC世界总决赛,并取得过世界第6名的佳绩。他的主要研究方向为数据库,在《计算机研究与发展》、《软件学报》以及重大学术会议上发表过多篇论文,参与翻译出版了《数据通信与网络》和《数据通信、计算机网络与开放系统》。
王建德,著名的信息学奥林匹克竞赛金牌教练,国务院特殊津贴专家,中学特级教师。他所辅导的学生在国际奥林匹克信息学竞赛(IOI)中获7金、3银、2铜的优异成绩,先后出版了24本关于程序设计和算法的学术专著,其中《实用算法的分析与程序设计》广受好评,长期以来是国内各类程序设计竞赛的必备教程。
ACM国际大学生程序设计竞赛(简称ACM/ICPC)是由美国计算机协会(ACM)主办的国际性大学生计算机学科竞赛,创办于1977年,竞赛以大学为单位,3人一队,先在各大洲进行各级预选赛,从中选拔优胜队参加全球总决赛。ACM/ICPC目前已经成为全世界范围内历时久远、规模宏大、影响*的权威性的大学生程序设计竞赛。
目录
前言
第一篇 基本能力的编程实验
第1章 简单计算的编程实验
1.1 改进程序书写风格的实验范例
1.2 正确处理多组测试数据的实验范例
1.3 提高实数精度的实验范例
1.4 使用二分法提高计算时效的实验范例
1.5 相关题库
第2章 简单模拟的编程实验
2.1 直叙式模拟的实验范例
2.2 筛选法模拟的实验范例
2.3 构造法模拟的实验范例
2.4 相关题库
第3章 简单递归的编程实验
3.1 计算递归函数的实验范例
3.2 用递归算法求问题解的实验范例
3.3 求解递归数据的实验范例
3.4 相关题库
本篇小结
第二篇 线性数据结构的编程实验
第4章 应用直接存取类线性表编程
4.1 数组应用一:日期计算的实验范例
4.2 数组应用二:高精度运算的实验范例
4.3 数组应用三:多项式表示与处理的实验范例
4.4 数组应用四:数值矩阵运算的实验范例
4.5 字符串处理一:串的存储结构的实验范例
4.6 字符串处理二:串模式匹配的实验范例
4.7 相关题库
第5章 应用顺序存取类线性表编程
5.1 顺序表应用的实验范例
5.2 栈应用的实验范例
5.3 队列应用的实验范例
5.4 相关题库
第6章 应用广义索引类线性表编程
6.1 使用词典解题的实验范例
6.2 使用散列表与散列方法解题的实验范例
6.3 相关题库
第7章 应用线性表排序编程
7.1 利用STL中自带的排序功能编程的实验范例
7.2 应用排序算法编程的实验范例
7.3 相关题库
本篇小结
第三篇 层次类非线性表的编程实验
第8章 采用树结构的非线性表编程
8.1 用树的遍历求解层次性问题的实验范例
8.2 用树结构支持并查集的实验范例
8.3 用树状数组统计子树权和的实验范例
8.4 相关题库
第9章 应用二叉树的基本概念编程
9.1 普通有序树转化为二叉树的实验范例
9.2 计算二叉树路径的实验范例
9.3 通过遍历确定二叉树结构的实验范例
9.4 相关题库
第10章 应用经典二叉树编程
10.1 二叉搜索树的实验范例
10.2 二叉堆的实验范例
10.3 哈夫曼树的实验范例
10.4 相关题库
本篇小结
第四篇 群聚类非线性表的编程实验
第11章 应用图的遍历算法编程
11.1 BFS算法的实验范例
11.2 DFS算法的实验范例
11.3 拓扑排序的实验范例
11.4 计算无向图的连通性的实验范例
11.5 相关题库
第12章 应用最小生成树算法编程
12.1 Kruskal算法的实验范例
12.2 Prim算法的实验范例
12.3 相关题库
第13章 应用最佳路径算法编程
13.1 Warshall算法和Floyed-Warshall算法的实验范例
13.2 Dijkstra算法的实验范例
13.3 Bellman-Ford算法的实验范例
13.4 SPFA算法的实验范例
13.5 相关题库
第14章 应用特殊图的经典算法编程
14.1 二分图匹配的实验范例
14.2 计算网络最大流的实验范例
14.3 相关题库
本篇小结
前沿
我们长期从事数据结构教学和竞赛培训,教学实践使我们萌发了对数据结构课程的教学模式进行改革的想法:
1)在课程中需要增加思维方式和解题策略的引导,引导学生思考各类数据结构的本质特征是什么;面对当前问题为什么要采用这样的数据结构而不宜采用那样的数据结构;当有多个数据结构可用时,怎样权衡时间复杂度、空间复杂度、编程复杂度和思维复杂度四个因素,寻找最合时宜的数据结构,将“知识导向”与“智慧导向”真正结合起来。
2)在课程中需要引入案例教学,通过模拟或者重现现实生活中的一些场景,让学生置身问题情境之中,通过思考、讨论和上机编程来进行学习。传统教学将数据结构“束之高阁”,在理论教学和笔试上兜来兜去,可能会使学生浑然不知数据结构在现实生活中究竟派什么用处,懵懵懂懂,最终失去了学习的意义。“纸上得来终觉浅,绝知此事要躬行”。案例教学则是一种以问题和动手编程驱动学习的方式:将知识置于问题情境和实践过程之中,变枯燥乏味为生动活泼。学生拿到试题后,先进行审题,然后温习或查阅各种他认为必要的数据结构知识,这无形中激发了他们的求知欲望,加深了他们对知识真谛的理解。捕捉到相关的理论知识后,学生还要经过缜密思考和动手编程,使之变为解决问题的程序方案。这个“认识-实践-再认识-再实践”的过程,应视为知识理解上的一种提高,知识学习与应用能力间的一种转变和升华。
基于上述想法,我们近年来开设了“数据结构实验”课程,并将ACM国际大学生程序设计竞赛和其他程序设计竞赛中的典型试题分门别类,精选了其中204道试题,翻译后作为学习数据结构知识的实验案例。这些试题不仅为相关知识创设了丰富有趣的问题背景,而且在相关网站上都有试题的在线测试。学生不仅可以带着问题学习数据结构,而且所编程序的正确性和效率也可以通过相关网站上的测试系统得到实时检验,达到“学以致用”的目的。
本书试题的在线测试地址主要有:
在线评测系统 简称 网址
北京大学在线评测系统 POJ http://poj.org/
浙江大学在线评测系统 ZOJ http://acm.zju.edu.cn/onlinejudge/
UVA在线评测系统 UVA http://uva.onlinejudge.org/
http://livearchive.onlinejudge.org/
Ural在线评测系统 Ural http://acm.timus.ru/
SGU在线评测系统 SGU http://acm.sgu.ru/
本书按照数据结构的知识结构和循序渐进的原则,共分四大篇(基本能力的编程实验、线性数据结构的编程实验、层次类非线性表的编程实验、群聚类非线性表的编程实验)14个章节。每个章节为相关数据结构知识提供了大量的实验范例,并且建立了相关的试题库,其中实验范例68道,题库试题136道。每个实验范例不仅有知识要点阐述和详尽的试题解析,还列出了写有详细注释的参考程序;题库中的所有试题无论难易,都有清晰的提示。教师既可以将实验范例作为开设数据结构实验课程的教材,也可以从相关题库中挑选数据结构实验课程的作业、考题或指导ACM集训活动的培训资料。每道题都注明了试题来源和在线测试网址,考虑到网站更新给读者学习带来不便的可能情况,本书还附带了存储所有试题的英文原版描述和大部分试题的测试数据等资料的光盘。我们之所以这样做,就是力图构建一个尽可能丰富、实用和长效的数据结构实验课程资源库。
需要说明的是,本书是在复旦大学ACM集训队长期活动的基础上积累而成的。阿拉法特·居来提、姚哲云、张昊等同学精心编写了所有程序,每道程序都通过了严格的测试验证,其中一些程序经多次修改,精益求精。这些同学为本书的出版付出了辛勤的劳动,作出了不可或缺的贡献。在此,向他们表示由衷的感激。另外,衷心感谢复旦大学计算机学院2006、2007、2008级同学在使用本书讲义过程中提出的宝贵意见和建议。
由于时间和水平所限,书中肯定夹杂了不少缺点和错误,表述不当和笔误更是在所难免,热忱欢迎学术界同仁和读者赐正。如果你在阅读中发现了问题,请通过书信或电子邮件告诉我们,以便及时整理成勘误表放在本书的专门网站上,供广大读者查询更正。我们更期望读者对本书提出建设性意见,以便再版时改进。我们的联系方式是:
通信地址:上海市邯郸路220号复旦大学计算机科学技术学院 吴永辉
邮编:200433
 ;
免费在线读
第一篇
基本能力的编程实验
 ; ; ;数据结构实验课程不是听会的,也不是看会的,而是练会的,是让学生在充分上机动手编程的过程中逐步学会的。数据结构的先导课程是程序设计语言,其教学目的是让学生学会用计算机编程语言编写程序。因此,我们在数据结构实验课伊始,先引领学生“温故知新”,开展三个方面的编程实验:简单计算,简单模拟,简单递归。这三类实验既是程序设计语言课程的温习,也是数据结构实验课程的入门和前奏。
第1章
简单计算的编程实验
 ; ; ;所谓简单计算题,指的是“输入-处理-输出”模式中,处理环节涉及的运算规则比较浅显,编程的重心应放在如何正确地输入、输出或优化计算上。学生可以通过编程解简单计算题的实验,掌握C/C++或Java程序设计语言的基本语法,熟悉在线测试系统和编程环境,初步学会怎样将一个自然语言描述的实际问题抽象成一个计算问题,给出计算过程,继而编程实现计算过程,并将计算结果还原成对原来问题的解答。
 ; ; ;虽然简单计算题的运算相对简单,但还是应该取“取轻若重”的科学态度。因为试题的输入输出格式是多样的,而计算精度和时效一般有严格的定义。“细节决定成败”,一些编程细节若处理不好,则会导致整个程序“功亏一篑”。下面,我们将讨论几个相关问题:
1)改进程序书写风格;
2)正确处理多组测试数据;
3)提高实数的计算精度;
4)用二分法提高计算效率。
 ; ; ;一般来讲,较复杂的问题大都由一些含简单计算的子问题组合而成。“万丈高楼平地起”,要提高编程能力,需要从娴熟简单计算题的解题方法做起。
数据结构编程实验:大学程序设计课程与竞赛训练教材(附光盘) pdf下载声明
本pdf资料下载仅供个人学习和研究使用,不能用于商业用途,请在下载后24小时内删除。如果喜欢,请购买正版