![]()
内容推荐 本书简要介绍了ACM-ICPC(ACM国际大学生程序设计竞赛)、算法和算法设计的基础知识,重点讲解算法设计方法,给出了ACM-ICPC中常用的10种算法设计方法:求值法、递推法、递归法、枚举法、模拟法、分治法、贪心法、回溯法、构造法和动态规划法。该书针对每种程序设计方法,首先阐述该方法的基本思想,然后通过典型例题进行详细讲解,最后通过实战训练予以巩固和提高。 本书注重ACM-ICPC的基本算法,思想高度概括、例题深入浅出、实战耐人寻味。该书可作为ACM国际大学生程序设计竞赛和中学青少年信息学奥林匹克竞赛的指导书,也可作为IT技术人员和计算机编程爱好者的参考书。 目录 第1章ACM与算法概述 1.1ACM-ICPC简介 1.1.1历史 1.1.2比赛规则 1.1.3区域和全球决赛 1.2算法与问题求解 1.2.1算法的定义 1.2.2问题求解 1.3算法的特性 1.3.1算法的要素 1.3.2算法的基本特性 1.4算法的描述 1.4.1基本控制结构的描述 1.4.2C算法描述的约定 1.5算法分析 1.5.1算法的评价标准 1.5.2算法的时间复杂性 1.5.3算法的空间复杂性 1.6算法的优化 1.6.1全局优化 1.6.2局部优化 1.6.3算法优化中的注意事项 第2章求值法 2.1算法设计思想 2.2典型例题 2.2.1求优选数 2.2.2中位数和平均数 2.2.3判断闰年 2.2.4素数 2.2.5判断天数 2.2.6大整数阶乘 2.3实战训练 2.3.1求年长者 2.3.2一元二次方程求根 2.3.3三角形的面积 2.3.4优选公约数 2.3.5求整数的位数 2.3.6孪生素数 2.3.7求圆的周长 2.3.8阶乘求和 2.3.9计算圆周率 2.3.10求闰年 2.3.11连续自然数的平方和 2.3.12大整数求和问题 2.3.13公牛和母牛 2.3.14十六进制的运算 2.3.15亲和数 2.4小结 第3章递推法 3.1算法设计思想 3.2典型例题 3.2.1兔子繁殖问题 3.2.2优选公约数问题 3.2.3猴子吃桃问题 3.2.4杨辉三角问题 3.2.5穿越沙漠问题 3.2.6方格涂色问题 3.3实战训练 3.3.1求年龄 3.3.2斐波那契数列求和 3.3.3绝不后退 3.3.4取数 3.3.5王小二的刀 3.3.6蜜蜂回家 3.3.7富二代的生活费 3.3.8平面分割问题 3.3.9特殊性质的数 3.3.10求天数 3.3.11上楼梯 3.3.12开奖 3.3.13月之数 3.3.14洗牌 3.3.15飞跃悬崖 3.4小结 第4章递归法 4.1算法设计思想 4.2典型例题 4.2.1母牛繁殖问题 4.2.2输出各位数字 4.2.3优选值问题 4.2.4计算x的n次幂 4.2.5数组逆置 4.2.6汉诺塔问题 4.3实战训练 4.3.1递归取数 4.3.2递归拆数 4.3.3求素数之积 4.3.4反转字符串 4.3.5公共子序列 4.3.6卖鸭子 4.3.7进制转换 4.3.8角谷定理 4.3.9杨辉三角 4.3.10质因数分解 4.3.11全排列 4.3.12特殊性质的数 4.3.13放盘子 4.3.14无序划分 4.3.15回文数 4.4小结 第5章枚举法 5.1算法设计思想 5.2典型例题 5.2.1百鸡问题 5.2.2水仙花数 5.2.3完数 5.2.4可逆素数 5.2.5串匹配问题 5.2.6最小公倍数问题 5.2.7狱吏问题 5.3实战训练 5.3.1素数筛选问题 5.3.2纸币换硬币 5.3.3勾股数问题 5.3.4生理周期问题 5.3.5构造比例数 5.3.6自守数 5.3.7谁是窃贼 5.3.8独特的数 5.3.9握手问题 5.3.10趣味数学 5.3.11暴力枚举之绝对值 5.3.12回文数 5.3.13逆序对数 5.3.14放牧 5.3.15餐厅点餐 5.4小结 第6章模拟法 6.1算法设计思想 6.2典型例题 6.2.1电梯问题 6.2.2扑克洗牌问题 6.2.3进站时间模拟 6.2.4消息队列 6.2.5清除杂草 6.2.6机器人的指令 6.3实战训练 6.3.1报数问题 6.3.2无限次幂 6.3.3金币工资 6.3.4进制转换 6.3.5卡片魔术 6.3.6木棍上的蚂蚁 6.3.7串联数字 6.3.8多连块覆盖问题 6.3.9括号表达式 6.3.10假币问题 6.3.11会议安排 6.3.12取火柴游戏 6.3.13取石子游戏 6.3.14伪造的美元 6.3.15HTML浏览器 6.4小结 第7章分治法 7.1算法设计思想 7.2典型例题 7.2.1折半查找 7.2.2金块问题 7.2.3寻找第二的问题 7.2.4归并排序 7.2.5大整数乘法 7.2.6二叉树遍历 7.3实战训练 7.3.1数组二分求和 7.3.2子序列优选值 7.3.3棋盘覆盖 7.3.4最接近点对问题 7.3.5第k小元素问题 7.3.6循环赛日程表问题 7.3.7找假币问题 7.3.8n阶分形 7.3.9m叉树问题 7.3.10电话查重 7.3.11树的有效点对 7.3.12回文串交换 7.3.13史密斯数 7.3.14矩阵乘积 7.3.15士兵排队问题 7.4小结 第8章贪心法 8.1算法设计思想 8.2典型例题 8.2.1找零钱问题 8.2.2很优装载 8.2.3夫曼编码 8.2.4单源最短路径 8.2.5埃及分数问题 8.2.6多机调度问题 8.3实战训练 8.3.1小船过河问题 8.3.2纪念品分组 8.3.3数列极差问题 8.3.4函数求底问题 8.3.5开心的金明 8.3.6小明坐车问题 8.3.7田忌赛马 8.3.8装箱问题 8.3.9删数问题 8.3.10移动纸牌问题 8.3.11组合正整数 8.3.12活动安排问题 8.3.13多人接水问题1 8.3.14多人接水问题2 8.3.15搬桌子问题 8.4小结 第9章回溯法 9.1算法设计思想 9.2典型例题 9.2.1八皇后问题 9.2.2图着色问题 9.2.3桥本分数式 9.2.4高逐位整除数 9.2.5直尺刻度分布问题 9.2.6素数环问题 9.2.7伯努利装错信封问题 9.3实战训练 9.3.1排列问题 9.3.2低逐位整除数 9.3.3子集问题 9.3.4旅行售货员问题 9.3.5两组均分问题 9.3.6组合数问题 9.3.7运动员很好配对问题 9.3.8任务很好调度问题 9.3.9迷宫问题 9.3.10背包问题 9.3.11翻币问题 9.3.12最长滑雪问题 9.3.13流水线作业调度问题 9.3.14组合三角形问题 9.3.15情侣排列问题 9.4小结 第10章构造法 10.1算法设计思想 10.2典型例题 10.2.1计算π值 10.2.2求n的阶乘 10.2.3求第k大的数 10.2.4比赛日程表 10.2.5奇数阶魔方 10.2.6二叉树操作 10.3实战训练 10.3.1自然数倒数求和 10.3.2今夕是何日 10.3.3计算e值 10.3.4自数 10.3.5火星人 10.3.6整数平方后9位 10.3.7构造等式 10.3.8构造回文字符串 10.3.9开灯问题 10.3.10“1”的个数 10.3.11小明的烦恼 10.3.12乒乓球赛 10.3.13自然数拆分问题 10.3.14集卡片赢大奖 10.3.15括号匹配问题 10.4小结 第11章动态规划法 11.1算法设计思想 11.2典型例题 11.2.1数塔问题 11.2.2矩阵连乘问题 11.2.3最长公共子序列问题 11.2.4最长上升子序列问题 11.2.5陪审团问题 11.3实战训练 11.3.1最少硬币问题 11.3.2编辑距离问题 11.3.3石子合并问题 11.3.4最小m段和问题 11.3.5优选长方体问题 11.3.6优选k乘积问题 11.3.7最少费用购物问题 11.3.8很优时间表问题 11.3.9矩形嵌套问题 11.3.10导弹拦截问题 11.3.11C小加问题 11.3.12接近背包问题 11.3.13分邮票问题 11.3.14排列问题 11.3.15接近覆盖问题 11.4小结 参考文献 |