本书每章为一个主题,实验内容安排紧扣大学算法和数学的教学,用程序设计竞赛中的算法和数学试题作为实验试题,将算法和数学的教学与程序设计竞赛的解题训练结合在一起;在思维方式和解题策略的训练方面,以问题驱动和启发式引导为主要方式,培养读者通过编程解决问题的能力。
本书特点:
书中给出的234道试题全部精选自ACM国际大学生程序设计竞赛的世界总决赛以及各大洲赛区现场赛和网络预赛、大学程序设计竞赛、在线比赛和其他诸如IOI等程序设计竞赛题目,时间跨度为1989年到2010年,这些试题均能通过在线提交的方式进行实时检验,从而方便读者进行实验和练习。
本书提供了官方的原版试题、测试数据和解答程序作为参考,读者可以通过对官方的测试数据的分析,了解测试数据的特点和常见陷阱,在以后的编程中提高解题质量和正确性。
各章的实验范例可以用于大学算法课程的教学与实验,在此基础上使用题库进行解题,还可以辅导学生进行程序设计竞赛的专项训练。
本书提供了试题的英文原版描述和大部分试题的测试数据,读者可登录华章网站(http://www.hzbook.com)下载。
前言
第1章 求解Ad Hoc类问题的编程实验1
1.1 机理分析法的实验范例1
1.2 统计分析法的实验范例5
1.3 相关题库10
第2章 模拟法的编程实验35
2.1 直叙式模拟的实验范例36
2.2 筛选法模拟的实验范例44
2.3 构造法模拟的实验范例51
2.4 相关题库55
第3章 数论的编程实验69
3.1 素数运算的实验范例69
3.1.1 使用筛法生成素数的实验范例69
3.1.2 测试大素数的实验范例76
3.2 求解不定方程和同余方程的实验范例81
3.2.1 计算最大公约数和不定方程81
3.2.2 计算同余方程和同余方程组85
3.3 积性函数的实验范例91
3.3.1 使用欧拉函数φ(n)计算与n互质的正整数个数 92
3.3.2 使用莫比乌斯函数μ(n)计算非平方数n的质因子个数97
3.4 相关题库102
第4章 组合分析的编程实验118
4.1 生成排列组合的实验范例118
4.1.1 按字典序思想生成下一排列组合118
4.1.2 按字典序思想生成所有的排列组合121
4.2 排列组合计数的实验范例122
4.2.1 一般的排列组合计数公式123
4.2.2 两种特殊的排列组合计数公式126
4.3 容斥原理与抽屉原理的实验范例132
4.3.1 利用抽屉原理求解存在性问题132
4.3.2 利用容斥原理对并集计数134
4.4 波利亚定理的实验范例140
4.4.1 波利亚定理的概念基础141
4.4.2 利用波利亚定理计算集合在置换群作用下产生的等价类个数148
4.5 相关题库157
第5章 贪心法的编程实验165
5.1 体验贪心法内涵的实验范例165
5.2 利用数据有序化进行贪心选择的实验范例172
5.3 在综合性的P类问题中使用贪心法的实验范例181
5.4 相关题库187
第6章 动态规划(DP)方法的编程实验197
6.1 线性DP的实验范例198
6.1.1 初步体验线性DP问题198
6.1.2 子集和问题202
6.1.3 最长公共子序列问题203
6.1.4 最长递增子序列问题206
6.2 树形DP的实验范例213
6.3 状态压缩DP的实验范例218
6.4 单调优化1D/1D DP的实验范例224
6.4.1 经典模型1:利用决策代价函数w的单调性优化224
6.4.2 经典模型2:利用决策区间下界的单调性优化228
6.4.3 经典模型3:利用最优决策点的凸性优化233
6.5 相关题库236
第7章 高级数据结构的编程实验273
7.1 后缀数组的实验范例273
7.1.1 使用倍增算法计算名次数组和后缀数组273
7.1.2 计算最长公共前缀276
7.1.3 后缀数组的应用278
7.2 线段树的实验范例288
7.2.1 线段树的基本概念和基本操作288
7.2.2 线段树单点更新的维护290
7.2.3 线段树子区间更新的维护293
7.3 处理特殊图的实验范例306
7.3.1 计算欧拉图306
7.3.2 计算哈密尔顿图314
7.3.3 计算最大独立集324
7.3.4 计算割点、桥和双连通分支327
7.4 相关题库336
第8章 计算几何的编程实验354
8.1 点线面运算的实验范例354
8.1.1 计算点积和叉积354
8.1.2 计算线段交361
8.1.3 利用欧拉公式计算多面体371
8.2 利用扫描线算法计算矩形的面积并375
8.2.1 沿垂直方向计算矩形的面积并375
8.2.2 沿水平方向计算矩形的面积并380
8.3 计算半平面交的实验范例383
8.3.1 计算半平面交的联机算法384
8.3.2 利用极角计算半平面交的算法390
8.4 计算凸包和旋转卡壳的实验范例398
8.4.1 计算凸包399
8.4.2 旋转卡壳实验403
8.5 相关题库408
《从心理问题到心理优势》内容简介:这是一个重度抑郁症患者执着探寻心灵光源的生命足迹。这本书不同于那些年我们食过的心灵鸡汤,
《TensorFlow机器学习(原书第2版)》内容简介:本书是升级版,不仅包含机器学习的基本概念,以及如何利用TensorFlow库快速构建强大
《软件开发的201个原则》内容简介:本书汇总了软件工程原则。原则是关于软件工程的基本原理、规则或假设,不管所选的技术、工具或语
《Web渗透技术及实战案例解析》从Web渗透的专业角度,结合网络安全中的实际案例,图文并茂地再现Web渗透的精彩过程。《Web渗透技
Visual Basic程序设计 本书特色 为了适应信息化时代的需求,各高校对大多数专业都开设了一定的计算机语言课程,有的讲授C或C++语言,有的讲授Visua...
《Node与Express开发》内容简介:本书系统讲解了使用Express开发动态Web应用的流程和步骤。作者不仅讲授了开发公共站点及REST API的
《Minecraft我的世界》内容简介:越玩越聪明! Minecraft我的世界是一款高自由度的沙盒建造游戏,玩家可以在游戏中的三维空间里创造
《移动界面(Web/App)Photoshop UI设计十全大补》内容简介:智能手机App,UI设计是目前比较热门的专业,也是一块新兴的平面设计领
《智能物联网》内容简介:本书探讨了物联网的现状和未来发展趋势,以及所面临的相关安全问题。作者艾哈迈德·巴纳法(Ahmed Banafa
《亨利·雷马克与比较文学关系研究》内容简介:亨利·雷马克是美籍德裔著名比较文学学者,文艺理论家。1961年他发表的《比较文学的
NicholasC.Zakas是一名前端开发顾问、作者和演讲家。在Yahoo!供职超过5年时间,在这期间他曾是Yahoo!首页首席前端工程师和YUI库
《沙漠之城》内容简介:埃及,一个充满了妖艳而疯狂气息的沙漠之域。旅行探险家本尼西本想在这里体验一番奇妙的异域风情,探寻传说
《射频与微波工程实践导论》从回顾交流分析开始,介绍了谐振腔、Q定义及基于Q的阻抗匹配,在此基础上介绍了分布电路设计,并逐步
本书全面介绍了交互设计的基本理论,从界面设计、交互原理到用户体验,囊括了所有专业知识点,并通过列举大量具有开创性的交互设
《Windows并发编程指南》详细讲述Windows并发编程的相关知识。内容分为四个部分:第一部分“概念”从高层视角介绍并发的基本概念
《历史文化名城名镇名村系列:东村》内容简介:东村,古称“东园村”,这个太湖边尚存的为数不多的千年古村,历史遗存丰富,现存明
FloTHERM软件基础与应用实例-(第二版) 本书特色 本书分为软件基础入门与应用实例两大部分,全书共计17章节。1~11章节为软件基础入门,其内容以热仿真工...
盛大游戏原画设计精选 内容简介 精选我国著名网络游戏公司盛大公司自主研发的游戏原画,内容包括草图设计、图面渲染、成图效果等设计过程,南京艺术学院游戏专业的专家对...
本书并不具体地描述某一技术的细节,而是尽量从宏观上、从历史的角度来描述通信产业的发展和变迁,描述在一个通信基础设施中使用
专转本计算机应用基础考试核心密卷 内容简介 本书紧扣2005年计算及应用基础考试内容,分理论题和操作题两部分。本书前十套试卷是对计算机应用基础知识体系与操作实践...