本书每章为一个主题,实验内容安排紧扣大学算法和数学的教学,用程序设计竞赛中的算法和数学试题作为实验试题,将算法和数学的教学与程序设计竞赛的解题训练结合在一起;在思维方式和解题策略的训练方面,以问题驱动和启发式引导为主要方式,培养读者通过编程解决问题的能力。
本书特点:
书中给出的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
《猕猴桃优质高效标准化栽培技术》内容简介:本书介绍了猕猴桃种质资源与良种选育、育苗、建园、土肥水与花果管理、整形修剪、树体
MATLAB图像函数查询使用手册 本书特色 MATLAB图像处理工具箱是目前*流行的图像处理工具之一,其函数能有效地实现各种图像算法。本书从实用角度出发,详细介...
Inlife,uncertaintysurroundsus.Thingsthatwethoughtweregoodforusturnouttobebadforu...
EDIUS视音频制作标准教程-(第2版)-(含2DVD价格) 本书特色 本书全面讲解edius*新核心技术,精选多个行业实用案例,帮助读者在*短的时间内从“零基...
《无线局域网设计与优化》内容简介:《无线局域网设计与优化》从WLAN的起源和演进出发,简洁而又直观地描述了基于IEEE 802.11 协议
《最美的季节去最美的地方》内容简介:时光匆匆,四季轮回,大自然总会带给我们不一样的惊喜。我国地大物博,旅游资源丰富,在不同
为了彻底理解是什么使得Linux能正常运行以及其为何能在各种不同的系统中运行良好,你需要深入研究内核最本质的部分。内核处理CPU
《当代中国高等教育》内容简介:教育规划纲要颁布实施以来,高等教育改革的进程如火如荼。那么在改革的过程中我们遇到了哪些矛盾和
《国外计算机科学教材系列·用TCP/TP进行网际互联(第3卷):客户-服务器编程与应用(Linux.POSIX套接字版)》是一部关于计算机网络的
ASP动态网页设计 本书特色 本书基于某信息科技有限公司的网站建设项目和网页设计岗位的能力要求,以网站建设工作过程为导向,以静态网页制作所必需的html、css...
《魔兽世界编程宝典:WorldofWarcraftAddons完全参考手册》可以为以下对象提供帮助:希望学习如何修改已有插件的新手插件用户,希
《网店运营与管理实务》内容简介:本书以就业为导向,以能力为本位,采用项目任务驱动的体例,每个项目以具体任务为主线展开,每个
本书是一部论述中国自史前至近代数千年纺织生产和工艺技术发展历史的著作。全书分为四编。第一编阐述古代的纺织生产情况;第二编
《可伸缩架构(第2版):云环境下的高可用与风险管理》内容简介:《可伸缩架构(第2版):云环境下的高可用与风险管理》是一本关于
计算机网络安全教程-(修订本) 本书特色 《计算机网络安全教程》(修订本)在原书基础上做了大量修整和扩充,使之更加适合高校教学和自学的需要。利用大量的实例讲解知...
WithPHPfortheWorldWideWeb,ThirdEdition:VisualQuickStartGuide,readerscanstartfrom...
RoR(RubyonRails)是基于动态脚本语言——Ruby语言的Web开发框架,其主要应用领域是Web应用程序的开发。使用RoR开发优势在于简便
《50件改变世界的裙装》讲述了:你不必是一个追逐时尚的人,或是设计爱好者,也不用奢望一件裙装就能改变整个社会。阅读本书即是
《Java就业培训教程》全书共分11章。第1章详细地讲解了Java开发环境的搭建、反编译工具的使用、JDK文档资料的查阅以及Java程序的
《华侨华人文献学刊·第五辑》内容简介:《华侨华人文献学刊》是以华侨华人文献为研究对象的国际化、学术性专题学刊,内容包括华侨