注册 | 登录读书好,好读书,读好书!
读书网-DuShu.com
当前位置: 首页出版图书教育/教材/教辅教材研究生/本科/专科教材ACM-ICPC基本算法

ACM-ICPC基本算法

ACM-ICPC基本算法

定 价:¥39.00

作 者: 滕国文,李昊
出版社: 清华大学出版社
丛编项:
标 签: 暂缺

购买这本书可以去


ISBN: 9787302503132 出版时间: 2018-08-01 包装:
开本: 16 页数: 222 字数:  

内容简介

  《ACM-ICPC基本算法》简要介绍了ACM-ICPC(ACM国际大学生程序设计竞赛)、算法和算法设计的基础知识,重点讲解算法设计方法,给出了ACM-ICPC中常用的10种算法设计方法:求值法、递推法、递归法、枚举法、模拟法、分治法、贪心法、回溯法、构造法和动态规划法。本书针对每种程序设计方法,首先阐述该方法的基本思想,然后通过典型例题进行详细讲解,最后通过实战训练予以巩固和提高。 本书注重ACM-ICPC的基本算法,思想高度概括、例题深入浅出、实战耐人寻味。本书可作为ACM国际大学生程序设计竞赛和中学青少年信息学奥林匹克竞赛的指导书,也可作为IT技术人员和计算机编程爱好者的参考书。

作者简介

暂缺《ACM-ICPC基本算法》作者简介

图书目录

  目  录

  

  

  

  


第1章  ACM与算法概述 1

1.1  ACM-ICPC简介 1

1.1.1  历史 1

1.1.2  比赛规则 2

1.1.3  区域和全球决赛 2

1.2  算法与问题求解 2

1.2.1  算法的定义 3

1.2.2  问题求解 3

1.3  算法的特性 5

1.3.1  算法的要素 5

1.3.2  算法的基本特性 6

1.4  算法的描述 6

1.4.1  基本控制结构的描述 7

1.4.2  C算法描述的约定 9

1.5  算法分析 11

1.5.1  算法的评价标准 11

1.5.2  算法的时间复杂性 12

1.5.3  算法的空间复杂性 13

1.6  算法的优化 14

1.6.1  全局优化 14

1.6.2  局部优化 15

1.6.3  算法优化中的注意事项 16

第2章  求值法 18

2.1  算法设计思想 18

2.2  典型例题 18

2.2.1  求最大数 18

2.2.2  中位数和平均数 19

2.2.3  判断闰年 20

2.2.4  素数 21

2.2.5  判断天数 23

2.2.6  大整数阶乘 24

2.3  实战训练 25

2.3.1  求年长者 25

2.3.2  一元二次方程求根 26

2.3.3  三角形的面积 26

2.3.4  最大公约数 26

2.3.5  求整数的位数 27

2.3.6  孪生素数 27

2.3.7  求圆的周长 27

2.3.8  阶乘求和 28

2.3.9  计算圆周率 28

2.3.10  求闰年 29

2.3.11  连续自然数的平方和 29

2.3.12  大整数求和问题 29

2.3.13  公牛和母牛 30

2.3.14  十六进制的运算 30

2.3.15  亲和数 31

2.4  小结 31

第3章  递推法 32

3.1  算法设计思想 32

3.2  典型例题 33

3.2.1  兔子繁殖问题 33

3.2.2  最大公约数问题 34

3.2.3  猴子吃桃问题 35

3.2.4  杨辉三角问题 36

3.2.5  穿越沙漠问题 37

3.2.6  方格涂色问题 39

3.3  实战训练 40

3.3.1  求年龄 40

3.3.2  斐波那契数列求和 40

3.3.3  绝不后退 41

3.3.4  取数 41

3.3.5  王小二的刀 41

3.3.6  蜜蜂回家 42

3.3.7  富二代的生活费 42

3.3.8  平面分割问题 43

3.3.9  特殊性质的数 43

3.3.10  求天数 44

3.3.11  上楼梯 44

3.3.12  开奖 44

3.3.13  月之数 45

3.3.14  洗牌 45

3.3.15  飞跃悬崖 46

3.4  小结 46

第4章  递归法 47

4.1  算法设计思想 47

4.2  典型例题 47

4.2.1  母牛繁殖问题 47

4.2.2  输出各位数字 48

4.2.3  最大值问题 49

4.2.4  计算x的n次幂 51

4.2.5  数组逆置 52

4.2.6  汉诺塔问题 53

4.3  实战训练 54

4.3.1  递归取数 54

4.3.2  递归拆数 55

4.3.3  求素数之积 55

4.3.4  反转字符串 56

4.3.5  公共子序列 56

4.3.6  卖鸭子 56

4.3.7  进制转换 57

4.3.8  角谷定理 57

4.3.9  杨辉三角 58

4.3.10  质因数分解 58

4.3.11  全排列 58

4.3.12  特殊性质的数 59

4.3.13  放盘子 59

4.3.14  无序划分 60

4.3.15  回文数 60

4.4  小结 60

第5章  枚举法 62

5.1  算法设计思想 62

5.2  典型例题 62

5.2.1  百鸡问题 62

5.2.2  水仙花数 63

5.2.3  完数 64

5.2.4  可逆素数 65

5.2.5  串匹配问题 67

5.2.6  最小公倍数问题 69

5.2.7  狱吏问题 71

5.3  实战训练 72

5.3.1  素数筛选问题 72

5.3.2  纸币换硬币 73

5.3.3  勾股数问题 73

5.3.4  生理周期问题 73

5.3.5  构造比例数 74

5.3.6  自守数 75

5.3.7  谁是窃贼 75

5.3.8  独特的数 76

5.3.9  握手问题 76

5.3.10  趣味数学 77

5.3.11  暴力枚举之绝对值 77

5.3.12  回文数 78

5.3.13  逆序对数 79

5.3.14  放牧 79

5.3.15  餐厅点餐 80

5.4  小结 81

第6章  模拟法 82

6.1  算法设计思想 82

6.2  典型例题 82

6.2.1  电梯问题 82

6.2.2  扑克洗牌问题 83

6.2.3  进站时间模拟 85

6.2.4  消息队列 86

6.2.5  清除杂草 89

6.2.6  机器人的指令 92

6.3  实战训练 93

6.3.1  报数问题 93

6.3.2  无限次幂 94

6.3.3  金币工资 95

6.3.4  进制转换 95

6.3.5  卡片魔术 96

6.3.6  木棍上的蚂蚁 96

6.3.7  串联数字 97

6.3.8  多连块覆盖问题 98

6.3.9  括号表达式 99

6.3.10  假币问题 100

6.3.11  会议安排 101

6.3.12  取火柴游戏 102

6.3.13  取石子游戏 103

6.3.14  伪造的美元 103

6.3.15  HTML浏览器 104

6.4  小结 105

第7章  分治法 106

7.1  算法设计思想 106

7.2  典型例题 106

7.2.1  折半查找 106

7.2.2  金块问题 108

7.2.3  寻找第二的问题 110

7.2.4  归并排序 112

7.2.5  大整数乘法 114

7.2.6  二叉树遍历 115

7.3  实战训练 118

7.3.1  数组二分求和 118

7.3.2  子序列最大值 118

7.3.3  棋盘覆盖 118

7.3.4  最接近点对问题 120

7.3.5  第k小元素问题 120

7.3.6  循环赛日程表问题 121

7.3.7  找假币问题 121

7.3.8  n阶分形 122

7.3.9  m叉树问题 122

7.3.10  电话查重 123

7.3.11  树的有效点对 124

7.3.12  回文串交换 125

7.3.13  史密斯数 125

7.3.14  矩阵乘积 126

7.3.15  士兵排队问题 126

7.4  小结 127

第8章  贪心法 128

8.1  算法设计思想 128

8.2  典型例题 129

8.2.1  找零钱问题 129

8.2.2  最优装载 130

8.2.3  哈夫曼编码 132

8.2.4  单源最短路径 136

8.2.5  埃及分数问题 139

8.2.6  多机调度问题 141

8.3  实战训练 144

8.3.1  小船过河问题 144

8.3.2  纪念品分组 144

8.3.3  数列极差问题 145

8.3.4  函数求底问题 145

8.3.5  开心的金明 146

8.3.6  小明坐车问题 147

8.3.7  田忌赛马 147

8.3.8  装箱问题 148

8.3.9  删数问题 148

8.3.10  移动纸牌问题 149

8.3.11  组合正整数 149

8.3.12  活动安排问题 150

8.3.13  多人接水问题1 150

8.3.14  多人接水问题2 151

8.3.15  搬桌子问题 151

8.4  小结 152

第9章  回溯法 153

9.1  算法设计思想 153

9.2  典型例题 153

9.2.1  八皇后问题 153

9.2.2  图着色问题 155

9.2.3  桥本分数式 158

9.2.4  高逐位整除数 160

9.2.5  直尺刻度分布问题 162

9.2.6  素数环问题 164

9.2.7  伯努利装错信封问题 167

9.3  实战训练 169

9.3.1  排列问题 169

9.3.2  低逐位整除数 169

9.3.3  子集问题 170

9.3.4  旅行售货员问题 170

9.3.5  两组均分问题 171

9.3.6  组合数问题 171

9.3.7  运动员最佳配对问题 172

9.3.8  任务最佳调度问题 172

9.3.9  迷宫问题 173

9.3.10  背包问题 174

9.3.11  翻币问题 174

9.3.12  最长滑雪问题 175

9.3.13  流水线作业调度问题 175

9.3.14  组合三角形问题 176

9.3.15  情侣排列问题 176

9.4  小结 177

第10章  构造法 178

10.1  算法设计思想 178

10.2  典型例题 179

10.2.1  计算π值 179

10.2.2  求n的阶乘 180

10.2.3  求第k大的数 181

10.2.4  比赛日程表 183

10.2.5  奇数阶魔方 185

10.2.6  二叉树操作 187

10.3  实战训练 189

10.3.1  自然数倒数求和 189

10.3.2  今夕是何日 189

10.3.3  计算e值 190

10.3.4  自数 190

10.3.5  火星人 191

10.3.6  整数平方后9位 192

10.3.7  构造等式 192

10.3.8  构造回文字符串 192

10.3.9  开灯问题 193

10.3.10  “1”的个数 193

10.3.11  小明的烦恼 194

10.3.12  乒乓球赛 194

10.3.13  自然数拆分问题 195

10.3.14  集卡片赢大奖 195

10.3.15  括号匹配问题 196

10.4  小结 196

第11章  动态规划法 198

11.1  算法设计思想 198

11.2  典型例题 199

11.2.1  数塔问题 199

11.2.2  矩阵连乘问题 201

11.2.3  最长公共子序列问题 205

11.2.4  最长上升子序列问题 207

11.2.5  陪审团问题 209

11.3  实战训练 212

11.3.1  最少硬币问题 212

11.3.2  编辑距离问题 213

11.3.3  石子合并问题 213

11.3.4  最小m段和问题 214

11.3.5  最大长方体问题 214

11.3.6  最大k乘积问题 215

11.3.7  最少费用购物问题 215

11.3.8  最优时间表问题 216

11.3.9  矩形嵌套问题 217

11.3.10  导弹拦截问题 218

11.3.11  C小加问题 218

11.3.12  完全背包问题 219

11.3.13  分邮票问题 220

11.3.14  排列问题 220

11.3.15  完全覆盖问题 221

11.4  小结 221

参考文献 223




本目录推荐