首页
编程语言与程序设计
Python编程导论 第2版
Python编程导论 第2版
书籍作者:约翰·谷泰格
ISBN:9787115473769
书籍语言:简体中文
连载状态:全集
电子书格式:pdf,txt,epub,mobi,azw3
下载次数:8864
创建日期:2021-02-14
发布日期:2021-02-14
运行环境:PC/Windows/Linux/Mac/IOS/iPhone/iPad/Kindle/Android/安卓/平板
内容简介
本书基于MIT 编程思维培训讲义写成,主要目标在于帮助读者掌握并熟练使用各种计算技术,具备用计算思维解决现实问题的能力。书中以Python 3 为例,介绍了对中等规模程序的系统性组织、编写、调试,帮助读者深入理解计算复杂度,还讲解了有用的算法和问题简化技术,并探讨各类计算工具的使用。与本书* 1版相比,* 2版全面改写了后半部分,且书中所有示例代码都从Python 2 换成了Python 3。
本书适合对编程知之甚少但想要使用计算方法解决问题的读者。
作者简介
John V. Guttag
1999年~2004年任MIT电气工程与计算机科学系主任,所授计算机科学系列导论课程深受学生欢迎。目前为计算机科学与人工智能实验室网络及移动系统组联合负责人,还进行软件工程、机器定理证明、硬件验证等领域的研究以及培训工作。获美国布朗大学英语专业学士学位、应用数学硕士学位,多伦多大学计算机科学博士学位。
编辑推荐
掌握多种不同的思维方式是每个人在大学时代的必修课。具备使用计算思维解决问题的能力是程序员入门的基本技能。本书基于作者开授的MIT热门MOOC教程编写,旨在培养读者的计算思维,为其日后的IT生涯打下坚实的编程基础。
- 以Python 3为示例,涵盖Python大部分特性,重在介绍编程语言可以做什么
- 如何系统性地组织、编写、调试中等规模的程序
- 理解计算复杂度
- 将模糊的问题描述转化为明确的计算方法,以此解决问题,并深刻理解整个过程
- 掌握有用的算法以及问题简化技术
- 使用随机性和模拟技术清晰阐述很难得到封闭解的问题
- 使用计算工具(包括简单的统计、可视化以及机器学习工具)对数据进行理解与建模
目录
第1章 启程 1 第2章 Python简介 6 2.1 Python基本元素 7 2.1.1 对象、表达式和数值类型 8 2.1.2 变量与赋值 9 2.1.3 Python IDE 11 2.2 程序分支 12 2.3 字符串和输入 14 2.3.1 输入 15 2.3.2 杂谈字符编码 16 2.4 迭代 17 第3章 一些简单的数值程序 20 3.1 穷举法 20 3.2 for循环 22 3.3 近似解和二分查找 24 3.4 关于浮点数 27 3.5 牛顿 拉弗森法 29 第4章 函数、作用域与抽象 31 4.1 函数与作用域 32 4.1.1 函数定义 32 4.1.2 关键字参数和默认值 33 4.1.3 作用域 34 4.2 规范 37 4.3 递归 39 4.3.1 斐波那契数列 40 4.3.2 回文 42 4.4 全局变量 45 4.5 模块 46 4.6 文件 47 第5章 结构化类型、可变性与 高阶函数 50 5.1 元组 50 5.2 范围 52 5.3 列表与可变性 52 5.3.1 克隆 57 5.3.2 列表推导 57 5.4 函数对象 58 5.5 字符串、元组、范围与列表 60 5.6 字典 61 第6章 测试与调试 65 6.1 测试 65 6.1.1 黑盒测试 66 6.1.2 白盒测试 68 6.1.3 执行测试 69 6.2 调试 70 6.2.1 学习调试 72 6.2.2 设计实验 72 6.2.3 遇到麻烦时 75 6.2.4 找到“目标”错误之后 76 第7章 异常与断言 77 7.1 处理异常 77 7.2 将异常用作控制流 80 7.3 断言 82 第8章 类与面向对象编程 83 8.1 抽象数据类型与类 83 8.1.1 使用抽象数据类型设计程序 87 8.1.2 使用类记录学生与教师 87 8.2 继承 90 8.2.1 多重继承 92 8.2.2 替换原则 93 8.3 封装与信息隐藏 94 8.4 进阶示例:抵押贷款 99 第9章 算法复杂度简介 103 9.1 思考计算复杂度 103 9.2 渐近表示法 106 9.3 一些重要的复杂度 107 9.3.1 常数复杂度 107 9.3.2 对数复杂度 108 9.3.3 线性复杂度 108 9.3.4 对数线性复杂度 109 9.3.5 多项式复杂度 109 9.3.6 指数复杂度 111 9.3.7 复杂度对比 112 * 10章 一些简单算法和数据结构 114 10.1 搜索算法 115 10.1.1 线性搜索与间接引用元素 115 10.1.2 二分查找和利用假设 116 10.2 排序算法 119 10.2.1 归并排序 120 10.2.2 将函数用作参数 122 10.2.3 Python中的排序 123 10.3 散列表 124 * 11章 绘图以及类的进一步扩展 128 11.1 使用PyLab绘图 128 11.2 进阶示例:绘制抵押贷款 133 * 12章 背包与图的* 优化问题 139 12.1 背包问题 139 12.1.1 贪婪算法 140 12.1.2 0/1背包问题的* 优解 143 12.2 图的* 优化问题 145 12.2.1 一些典型的图论问题 149 12.2.2 * 短路径:深度优先搜索和 广度优先搜索 149 * 13章 动态规划 155 13.1 又见斐波那契数列 155 13.2 动态规划与0/1背包问题 157 13.3 动态规划与分治算法 162 * 14章 随机游走与数据可视化 163 14.1 随机游走 163 14.2 醉汉游走 164 14.3 有偏随机游走 170 14.4 变幻莫测的田地 175 * 15章 随机程序、概率与分布 178 15.1 随机程序 178 15.2 计算简单概率 180 15.3 统计推断 180 15.4 分布 192 15.4.1 概率分布 194 15.4.2 正态分布 195 15.4.3 连续型和离散型均匀分布 199 15.4.4 二项式分布与多项式分布 200 15.4.5 指数分布和几何分布 200 15.4.6 本福德分布 203 15.5 散列与碰撞 204 15.6 强队的获胜概率 206 * 16章 蒙特卡罗模拟 208 16.1 帕斯卡的问题 209 16.2 过线还是不过线 210 16.3 使用查表法提高性能 213 16.4 求π的值 214 16.5 模拟模型结束语 218 第* 章 抽样与置信区间 220 17.1 对波士顿马拉松比赛进行抽样 220 17.2 中心极限定理 225 17.3 均值的标准误差 228 第* 章 理解实验数据 231 18.1 弹簧的行为 231 18.2 弹丸的行为 238 18.2.1 可决系数 240 18.2.2 使用计算模型 241 18.3 拟合指数分布数据 242 18.4 当理论缺失时 245 第* 章 随机试验与假设检验 247 19.1 检验显著性 248 19.2 当心P-值 252 19.3 单尾单样本检验 254 19.4 是否显著 255 19.5 哪个N 257 19.6 多重假设 258 第* 章 条件概率与贝叶斯统计 261 20.1 条件概率 262 20.2 贝叶斯定理 263 20.3 贝叶斯更新 264 第* 章 谎言、该死的谎言与统计学 267 21.1 垃圾输入,垃圾输出 267 21.2 检验是有缺陷的 268 21.3 图形会骗人 268 21.4 Cum Hoc Ergo Propter Hoc 270 21.5 统计测量不能说明所有问题 271 21.6 抽样偏差 272 21.7 上下文很重要 273 21.8 慎用外推法 273 21.9 得克萨斯神枪手谬误 274 21.10 莫名其妙的百分比 276 21.11 不显著的显著统计差别 276 21.12 回归假象 277 21.13 小心为上 278 第* 章 机器学习简介 279 22.1 特征向量 281 22.2 距离度量 283 第* 章 聚类 288 23.1 Cluster类 289 23.2 K-均值聚类 291 23.3 虚构示例 292 23.4 更真实的示例 297 第* 章 分类方法 303 24.1 分类器评价 303 24.2 预测跑步者的性别 306 24.3 K-* 邻近方法 308 24.4 基于回归的分类器 312 24.5 从“泰坦尼克”号生还 320 24.6 总结 325 Python 3.5速查表 326