下载 >  开发技术 >  Javascript > 数据结构与算法JavaScript描述 超清 非扫描 有目录

数据结构与算法JavaScript描述 超清 非扫描 有目录

随着JavaScript成功走出客户端,在服务器端编程中得到日益广泛的应用,JavaScript程序员需要实现与C#或Java等传统面向对象编程语言相似的数据结构与算法。本书是用JavaScript描述数据结构与算法的开山之作,汇聚了作者多年的实战经验。这本实战指南通过丰富的示例,向读者透彻讲解了在JavaScript环境下,如何通过一系列存储机制(包括链表、栈、队列和图)高效地达到编程目的。 通过本书的学习,读者将能自如地选择最合适的数据结构与算法,并在JavaScript开发中懂得权衡使用。此外,本书也概述了与数据结构与算法相关的JavaScript特性。 第 1 章 JavaScript的编程环境和模型 阅读 第 2 章 数组 第 3 章 列表 第 4 章 栈 第 5 章 队列 第 6 章 链表 第 7 章 字典 第 8 章 散列 第 9 章 集合 第 10 章 二叉树和二叉查找树 第 11 章 图和图算法 第 12 章 排序算法 第 13 章 检索算法 第 14 章 高级算法 封面介绍
2018-04-11 上传大小:21.59MB
想读
分享
收藏 (9) 举报
数据结构算法分析:java语言描述[第3版][超清][带目录书签]中文pdf+源码

数据结构与算法分析:java语言描述 第3版 超清完整版 有目录书签 pdf 附带源码 [美] 马克·艾伦·维斯 著,陈越 译 部分目录如下: 第1章 引论1 1.1 本书讨论的内容1 1.2 数学知识复习2 1.2.1 指数2 1.2.2 对数2 1.2.3 级数2 1.2.4 模运算4 1.2.5 证明的方法4 1.3 递归简论5 1.4 实现泛型构件pre-Java 57 1.4.1 使用Object表示泛型8 1.4.2 基本类型的包装9 1.4.3 使用接口类型表示泛型9 1.4.4 数组类型的兼容性10 1.5 利用Java 5泛型特性实现泛型构件11 1.5.1 简单的泛型类和接口11 1.5.2 自动装箱/拆箱11 1.5.3 菱形运算符12 1.5.4 带有限制的通配符12 1.5.5 泛型static方法14 1.5.6 类型限界14 1.5.7 类型擦除15 1.5.8 对于泛型的限制15 1.6 函数对象16 第2章 算法分析 第3章 表、栈和队列 第4章 树 第5章 散列 第6章 优先队列(堆) 第7章 排序 第8章 不相交集类 第9章 图论算法 第10章 算法设计技巧 第11章 摊还分析 第12章 高级数据结构及其实现

立即下载
数据结构算法分析 java语言描述(原书第3版)中文版超清PDF+源码.

数据结构与算法分析 java语言描述(原书第3版)中文PDF+源码 数据结构与算法分析 java语言描述(原书第3版)中文PDF+源码 数据结构与算法分析 java语言描述(原书第3版)中文PDF+源码.

立即下载
Javascript高级程序设计(第三版PDF)非扫描就敢号称最清晰

绝对不是扫描版可以比拟的,就敢号称最清晰的版本,就是这么自信!

立即下载
数据结构算法分析 java语言描述(原书第3版)中文PDF+源码

数据结构与算法分析Java版中文(PDF)附源码 本书是国外数据结构与算法分析方面的经典教材,使用卓越的Java编程语言作为实现工具讨论了数据结构(组织大量数据的方法)和算法分析(对算法运行时间的估计)。本书把算法分析与最有效率的Java程序的开发有机地结合起来,深入分析每种算法,内容全面、缜密严格,并细致讲解精心构造程序的方法。

立即下载
Python基础教程(第3版)原版高清带目录书签非扫描PDF

Python3.5编程从入门到实践 Python入门佳作 机器学习 人工智能 数据处理 网络爬虫热门编程语言 。本书是经典的Python入门教程,层次鲜明、结构严谨、内容翔实,特别是后面几章,作者将前面讲述的内容应用到10个引人入胜的项目中,并以模板的形式介绍了项目的开发过程,手把手教授Python编程实践,让读者从项目中领略Python的真正魅力。 本书既适合初学者夯实基础,又能帮助Python程序员提升技能,即使是中高级Python程序员,也能从书里找到耳目一新的内容。 本书包括Python程序设计的方方面面:首先从Python的安装开始,随后介绍了Python的基础知识和基本概念,包括列表、元组、字符串、字典以及各种语句;然后循序渐进地介绍了一些相对高级的主题,包括抽象、异常、魔法方法、属性、迭代器;此后探讨了如何将Python与数据库、网络、C语言等工具结合使用,从而发挥出Python的强大功能,同时介绍了Python程序测试、打包、发布等知识;最后,作者结合前面讲述的内容,按照实际项目开发的步骤向读者介绍了10个具有实际意义的Python项目的开发过程。

立即下载
数据结构算法分析:C语言描述(原书第2版)带目录扫描PDF+源代码+习题答案

数据结构与算法分析:C语言描述(原书第2版)带目录扫描PDF+源代码+习题答案。简单易懂,使用c语言描述算法,是一本不错的算法入门书。

立即下载
啊哈算法(超清+目录

啊哈算法(超清+目录)啊哈算法(超清+目录)啊哈算法(超清+目录)啊哈算法(超清+目录)啊哈算法(超清+目录)

立即下载
JavaScript权威指南(第6版)_带书签_超清完整版

[美] David Flanagan 著;淘宝前端团队 译; ISBN:9787111376613 扫描版的下载地址: http://download.csdn.net/download/e98123/10020855

立即下载
Linux内核设计与实现(第三版-中文版) 高清扫描版 带完整书签目录

《Linux内核设计与实现(原书第3版)》基于Linux 2.6.34内核详细介绍了Linux内核系统,覆盖了从核心内核系统的应用到内核设计与实现等各方面的内容。《Linux内核设计与实现(原书第3版)》主要内容包括:进程管理、进程调度、时间管理和定时器、系统调用接口、内存寻址、内存管理和页缓存、VFS、内核同步以及调试技术等。同时《Linux内核设计与实现(原书第3版)》也涵盖了Linux 2.6内核中颇具特色的内容,包括CFS调度程序、抢占式内核、块I/O层以及I/O调度程序等。《Linux内核设计与实现(原书第3版)》采用理论与实践相结合的路线,能够带领读者快速走进Linux内核世界,真正开发内核代码。《Linux内核设计与实现(原书第3版)》适合作为高等院校操作系统课程的教材或参考书,也可供相关技术人员参考。 如果你是一名linux内核爱好者,本书的内容可以帮助你大显身手。如果你是一名普通程序员,本书的内容将会拓宽你的编程思路。如果你初次接触linux内核,本书则可以帮助你对内核各个核心子系统有一个整体把握。 目录: 译者序 序言 前言 作者简介 第1章 Linux内核简介1 1.1 Unix的历史1 1.2 追寻Linus足迹:Linux简介2 1.3 操作系统和内核简介3 1.4 Linux内核和传统Unix内核的比较5 1.5 Linux内核版本7 1.6 Linux内核开发者社区8 1.7 小结8 第2章 从内核出发10 2.1 获取内核源码10 2.1.1 使用Git10 2.1.1 安装内核源代码10 2.1.3 使用补丁11 2.2 内核源码树11 2.3 编译内核12 2.3.1 配置内核12 2.3.2 减少编译的垃圾信息14 2.3.3 衍生多个编译作业 14 2.3.4 安装新内核14 2.4 内核开发的特点15 2.4.1 无libc库抑或无标准头文件15 2.4.2 GNU C16 2.4.3 没有内存保护机制18 2.4.4 不要轻易在内核中使用浮点数18 2.4.5 容积小而固定的栈18 2.4.6 同步和并发18 2.4.7 可移植性的重要性19 2.5 小结19 第3章 进程管理20 3.1 进程20 3.2 进程描述符及任务结构 21 3.2.1 分配进程描述符22 3.2.2 进程描述符的存放23 3.2.3 进程状态23 3.2.4 设置当前进程状态25 3.2.5 进程上下文25 3.2.6 进程家族树25 3.3 进程创建26 3.3.1 写时拷贝27 3.3.2 fork()27 3.3.3 vfork()28 3.4 线程在Linux中的实现28 3.4.1 创建线程29 3.4.2 内核线程30 3.5 进程终结31 3.5.1 删除进程描述符32 3.5.2 孤儿进程造成的进退维谷32 3.6 小结34 第4章 进程调度35 4.1 多任务35 4.2 Linux 的进程调度36 4.3 策略36 4.3.1 I/O消耗型和处理器消耗型的进程36 4.3.2 进程优先级37 4.3.3 时间片38 4.3.4 调度策略的活动38 4.4 Linux调度算法39 4.4.1 调度器类39 4.4.2 Unix 系统中的进程调度40 4.4.3 公平调度41 4.5 Linux调度的实现42 4.5.1 时间记账42 4.5.2 进程选择44 4.5.3 调度器入口48 4.5.4 睡眠和唤醒49 4.6 抢占和上下文切换51 4.6.1 用户抢占53 4.6.2 内核抢占53 4.7 实时调度策略54 4.8 与调度相关的系统调用54 4.8.1 与调度策略和优先级相关的系统调用55 4.8.2 与处理器绑定有关的系统调用55 4.8.3 放弃处理器时间56 4.9 小结56 第5章 系统调用57 5.1 与内核通信57 5.2 API、POSIX和C库57 5.3 系统调用58 5.3.1 系统调用号59 5.3.2 系统调用的性能59 5.4 系统调用处理程序60 5.4.1 指定恰当的系统调用60 5.4.2 参数传递60 5.5 系统调用的实现61 5.5.1 实现系统调用61 5.5.2 参数验证62 5.6 系统调用上下文64 5.6.1 绑定一个系统调用的最后步骤65 5.6.2 从用户空间访问系统调用67 5.6.3 为什么不通过系统调用的方式实现68 5.7 小结68 第6章 内核数据结构69 6.1 链表69 6.1.1 单向链表和双向链表69 6.1.2 环形链表70 6.1.3 沿链表移动71 6.1.4 Linux 内核中的实现71 6.1.5 操作链表73 6.1.6 遍历链表75 6.2 队列78 6.2.1 kfifo79 6.2.2 创建队列79 6.2.3 推入队列数据79 6.2.4 摘取队列数据80 6.2.5 获取队列长度80 6.2.6 重置和撤销队列80 6.2.7 队列使用举例 81 6.3 映射 81 6.3.1 初始化一个idr82 6.3.2 分配一个新的UID82 6.3.3 查找UID83 6.3.4 删除UID84 6.3.5 撤销idr84 6.4 二叉树84 6.4.1 二叉搜索树84 6.4.2 自平衡二叉搜索树 85 6.5 数据结构以及选择 87 6.6 算法复杂度88 6.6.1 算法88 6.6.2 大o 符号88 6.6.3 大θ符号89 6.6.4 时间复杂度89 6.7 小结 90 第7章 中断和中断处理91 7.1 中断91 7.2 中断处理程序92 7.3 上半部与下半部的对比93 7.4 注册中断处理程序93 7.4.1 中断处理程序标志94 7.4.2 一个中断例子95 7.4.3 释放中断处理程序95 7.5 编写中断处理程序96 7.5.1 共享的中断处理程序97 7.5.2 中断处理程序实例97 7.6 中断上下文99 7.7 中断处理机制的实现100 7.8 /proc/interrupts102 7.9 中断控制103 7.9.1 禁止和激活中断103 7.9.2 禁止指定中断线105 7.9.3 中断系统的状态105 7.10 小结106 第8章 下半部和推后执行的工作107 8.1 下半部107 8.1.1 为什么要用下半部108 8.1.2 下半部的环境108 8.2 软中断110 8.2.1 软中断的实现111 8.2.2 使用软中断113 8.3 tasklet114 8.3.1 tasklet的实现114 8.3.2 使用tasklet116 8.3.3 老的BH机制119 8.4 工作队列120 8.4.1 工作队列的实现121 8.4.2 使用工作队列124 8.4.3 老的任务队列机制126 8.5 下半部机制的选择127 8.6 在下半部之间加锁128 8.7 禁止下半部128 8.8 小结129 第9章 内核同步介绍131 9.1 临界区和竞争条件131 9.1.1 为什么我们需要保护132 9.1.2 单个变量133 9.2 加锁134 9.2.1 造成并发执行的原因135 9.2.2 了解要保护些什么136 9.3 死锁137 9.4 争用和扩展性138 9.5 小结140 第10章 内核同步方法141 10.1 原子操作141 10.1.1 原子整数操作142 10.1.2 64位原子操作144 10.1.3 原子位操作145 10.2 自旋锁147 10.2.1 自旋锁方法148 10.2.2 其他针对自旋锁的操作149 10.2.3 自旋锁和下半部150 10.3 读-写自旋锁150 10.4 信号量152 10.4.1 计数信号量和二值信号量153 10.4.2 创建和初始化信号量154 10.4.3 使用信号量154 10.5 读-写信号量155 10.6 互斥体156 10.6.1 信号量和互斥体158 10.6.2 自旋锁和互斥体158 10.7 完成变量158 10.8 BLK:大内核锁159 10.9 顺序锁160 10.10 禁止抢占161 10.11 顺序和屏障162 10.12 小结165 第11章 定时器和时间管理166 11.1 内核中的时间概念166 11.2 节拍率:HZ167 11.2.1 理想的HZ值168 11.2.2 高HZ的优势169 11.2.3 高HZ的劣势169 11.3 jiffies170 11.3.1 jiffies的内部表示171 11.3.2 jiffies 的回绕172 11.3.3 用户空间和HZ173 11.4 硬时钟和定时器174 11.4.1 实时时钟174 11.4.2 系统定时器174 11.5 时钟中断处理程序174 11.6 实际时间176 11.7 定时器178 11.7.1 使用定时器178 11.7.2 定时器竞争条件180 11.7.3 实现定时器180 11.8 延迟执行181 11.8.1 忙等待181 11.8.2 短延迟182 11.8.3 schedule_timeout()183 11.9 小结185 第12章 内存管理186 12.1 页186 12.2 区187 12.3 获得页189 12.3.1 获得填充为0的页190 12.3.2 释放页191 12.4 kmalloc()191 12.4.1 gfp_mask标志192 12.4.2 kfree()195 12.5 vmalloc()196 12.6 slab层197 12.6.1 slab层的设计198 12.6.2 slab分配器的接口200 12.7 在栈上的静态分配203 12.7.1 单页内核栈203 12.7.2 在栈上光明正大地工作203 12.8 高端内存的映射204 12.8.1 永久映射204 12.8.2 临时映射204 12.9 每个CPU的分配20512.10 新的每个CPU接口206 12.10.1 编译时的每个CPU数据206 12.10.2 运行时的每个CPU数据207 12.11 使用每个CPU数据的原因208 12.12 分配函数的选择209 12.13 小结209 第13章 虚拟文件系统210 13.1 通用文件系统接口210 13.2 文件系统抽象层211 13.3 Unix文件系统212 13.4 VFS 对象及其数据结构213 13.5 超级块对象214 13.6 超级块操作215 13.7 索引节点对象217 13.8 索引节点操作219 13.9 目录项对象222 13.9.1 目录项状态222 13.9.2 目录项缓存223 13.10 目录项操作224 13.11 文件对象225 13.12 文件操作226 13.13 和文件系统相关的数据结构230 13.14 和进程相关的数据结构232 13.15 小结233 第14章 块I/O层234 14.1 剖析一个块设备234 14.2 缓冲区和缓冲区头235 14.3 bio结构体237 14.3.1 I/O向量238 14.3.2 新老方法对比239 14.4 请求队列240 14.5 I/O调度程序240 14.5.1 I/O调度程序的工作241 14.5.2 Linus 电梯241 14.5.3 最终期限I/O调度程序242 14.5.4 预测I/O调度程序244 14.5.5 完全公正的排队I/O调度程序244 14.5.6 空操作的I/O调度程序245 14.5.7 I/O调度程序的选择245 14.6 小结246 第15章 进程地址空间247 15.1 地址空间247 15.2 内存描述符248 15.2.1 分配内存描述符249 15.2.2 撤销内存描述符250 15.2.3 mm_struct 与内核线程250 15.3 虚拟内存区域251 15.3.1 VMA标志251 15.3.2 VMA 操作253 15.3.3 内存区域的树型结构和内存区域的链表结构254 15.3.4 实际使用中的内存区域254 15.4 操作内存区域255 15.4.1 find_vma()256 15.4.2 find_vma_prev()257 15.4.3 find_vma_intersection()257 15.5 mmap()和do_mmap():创建地址区间258 15.6 mummap()和do_mummap():删除地址区间259 15.7 页表260 15.8 小结261 第16章 页高速缓存和页回写262 16.1 缓存手段262 16.1.1 写缓存262 16.1.2 缓存回收263 16.2 Linux 页高速缓存264 16.2.1 address_space对象264 16.2.2 address_space 操作266 16.2.3 基树267 16.2.4 以前的页散列表268 16.3 缓冲区高速缓存268 16.4 flusher线程268 16.4.1 膝上型计算机模式270 16.4.2 历史上的bdflush、kupdated 和pdflush270 16.4.3 避免拥塞的方法:使用多线程271 16.5 小结271 第17章 设备与模块273 17.1 设备类型273 17.2 模块274 17.2.1 Hello,World274 17.2.2 构建模块275 17.2.3 安装模块277 17.2.4 产生模块依赖性277 17.2.5 载入模块278 17.2.6 管理配置选项279 17.2.7 模块参数280 17.2.8 导出符号表282 17.3 设备模型283 17.3.1 kobject283 17.3.2 ktype284 17.3.3 kset285 17.3.4 kobject、ktype和kset的相互关系285 17.3.5 管理和操作kobject286 17.3.6 引用计数287 17.4 sysfs288 17.4.1 sysfs中添加和删除kobject 290 17.4.2 向sysfs中添加文件291 17.4.3 内核事件层293 17.5 小结294 第18章 调试295 18.1 准备开始295 18.2 内核中的bug296 18.3 通过打印来调试296 18.3.1 健壮性296 18.3.2 日志等级297 18.3.3 记录缓冲区298 18.3.4 syslogd和klogd298 18.3.5 从printf()到printk()的转换298 18.4 oops298 18.4.1 ksymoops300 18.4.2 kallsyms300 18.5 内核调试配置选项301 18.6 引发bug并打印信息301 18.7 神奇的系统请求键302 18.8 内核调试器的传奇303 18.8.1 gdb303 18.8.2 kgdb304 18.9 探测系统304 18.9.1 用UID作为选择条件304 18.9.2 使用条件变量305 18.9.3 使用统计量305 18.9.4 重复频率限制305 18.10 用二分查找法找出引发罪恶的变更306 18.11 使用Git进行二分搜索307 18.12 当所有的努力都失败时:社区308 18.13 小结308 第19章 可移植性309 19.1 可移植操作系统309 19.2 Linux移植史310 19.3 字长和数据类型311 19.3.1 不透明类型313 19.3.2 指定数据类型314 19.3.3 长度明确的类型314 19.3.4 char型的符号问题315 19.4 数据对齐315 19.4.1 避免对齐引发的问题316 19.4.2 非标准类型的对齐316 19.4.3 结构体填补316 19.5 字节顺序318 19.6 时间319 19.7 页长度320 19.8 处理器排序320 19.9 SMP、内核抢占、高端内存321 19.10 小结321 第20章 补丁、开发和社区322 20.1 社区322 20.2 Linux编码风格322 20.2.1 缩进323 20.2.2 switch 语句323 20.2.3 空格324 20.2.4 花括号325 20.2.5 每行代码的长度326 20.2.6 命名规范326 20.2.7 函数326 20.2.8 注释326 20.2.9 typedef327 20.2.10 多用现成的东西328 20.2.11 在源码中减少使用ifdef328 20.2.12 结构初始化328 20.2.13 代码的事后修正329 20.3 管理系统329 20.4 提交错误报告329 20.5 补丁330 20.5.1 创建补丁330 20.5.2 用Git创建补丁331 20.5.3 提交补丁331 20.6 小结332 参考资料333

立即下载
JavaScript高级程序设计第三版(文字版),非扫描版,超清

JavaScript高级程序设计第三版(文字版),非扫描版,超清

立即下载
数据结构算法分析(C语言描述)(中文版PDF高清)

数据结构与算法分析黑皮系列计算机经典图书,PDF高清影印版,C语言描述版本。是每个程序员提升技术的必经之路!

立即下载
数据结构算法 Python语言描述 裘宗燕 完整版 带书签

数据结构与算法 Python语言描述 裘宗燕 完整版 带书签

立即下载
数据结构算法分析c++描述(非扫描_完美标签_专业排版)

程序=算法+数据结构 c++描述的算法与数据结构。都是可以直接执行的,大大提高了阅读的效率。自己可以执行代码反复推敲。本书分为三个部分: 第一部分: 预备知识 第二部分: 数据结构 第三部分:算法设计方法 大家好!现在我们将要开始一个穿越“数据结构、算法和程序”这个抽象世界的特殊旅程, 以解决现实生活中的许多难题。在程序开发过程中通常需要做到如下两点:一是高效地描述数 据;二是设计一个好的算法,该算法最终可用程序来实现。要想高效地描述数据,必须具备数 据结构领域的专门知识;而要想设计一个好的算法,则需要算法设计领域的专门知识。 在着手研究数据结构和算法设计方法之前,需要你能够熟练地运用C + +编程并分析程序, 这些基本的技能通常是从C + +课程以及其他分散的课程中学到的。本书的前两章旨在帮助你回 顾一下这些技能,其中的许多内容你可能已经很熟悉了。

立即下载
算法导论(第三版)高清扫描版PDF(附目录

该书是一本十分经典的计算机算法书籍。《算法导论》自第一版出版以来,已经成为世界范围内广泛使用的大学教材和专业人员的标准参考手册。本书全面论述了算法的内容,从一定深度上涵盖了算法的诸多方面,同时其讲授和分析方法又兼顾了各个层次读者的接受能力。各章内容自成体系,可作为独立单元学习。所有算法都用英文和伪码描述,使具备初步编程经验的人也可读懂。

立即下载
邓俊辉数据结构第三版(c++版).pdf,高清不失真,可直接打印

邓俊辉数据结构第三版(c++版).pdf,高清不失真,可直接打印!!!

立即下载
学习JavaScript数据结构算法 超清 非扫描目录 中文

本书首先介绍了JavaScript语言的基础知识,接下来讨论了数组、栈、队列、链表、集合、字典、散列表、树、图等数据结构,之后探讨了各种排序和搜索算法,包括冒泡排序、选择排序、插入排序、归并排序、快速排序、顺序搜索、二分搜索,还介绍了动态规划和贪心算法等常用的高级算法及相关知识。 第1 章 JavaScript 简介 1 1.1 环境搭建 1 1.1.1 浏览器 2 1.1.2 使用Web 服务器(XAMPP) 3 1.1.3 使用Node.js 搭建Web 服务器 4 1.2 JavaScript 基础 6 1.2.1 变量 7 1.2.2 操作符 8 1.2.3 真值和假值 11 1.2.4 相等操作符(==和===) 12 1.3 控制结构 13 1.3.1 条件语句 14 1.3.2 循环 15 1.4 函数 16 1.5 面向对象编程 16 1.6 调试工具 18 1.7 小结 18 第2 章 数组 19 2.1 为什么用数组 19 2.2 创建和初始化数组 20 2.3 添加和删除元素 21 2.4 二维和多维数组 24 2.5 JavaScript 的数组方法参考 26 2.5.1 数组合并 27 2.5.2 迭代器函数 27 2.5.3 搜索和排序 28 2.5.4 输出数组为字符串 31 2.6 小结 32 第3 章 栈 33 3.1 栈的创建 33 3.2 从十进制到二进制 38 3.3 小结 39 第4 章 队列 40 4.1 创建队列 40 4.1.1 完整的Queue 类 42 4.1.2 使用Queue 类 43 4.2 优先队列 44 4.3 循环队列——击鼓传花 46 4.4 小结 47 第5 章 链表 48 5.1 创建一个链表 49 5.1.1 向链表尾部追加元素 50 5.1.2 从链表中移除元素 52 5.1.3 在任意位置插入一个元素 54 5.1.4 实现其他方法 56 5.2 双向链表 58 5.2.1 在任意位置插入一个新元素 59 5.2.2 从任意位置移除元素 61 5.3 循环链表 64 5.4 小结 64 第6 章 集合 65 6.1 创建一个集合 65 6.1.1 has(value)方法 66 6.1.2 add 方法 66 6.1.3 remove 和clear 方法 67 6.1.4 size 方法 68 6.1.5 values 方法 69 6.1.6 使用Set 类 69 6.2 集合操作 70 6.2.1 并集 70 6.2.2 交集 71 6.2.3 差集 72 6.2.4 子集 73 6.3 小结 74 第7 章 字典和散列表 75 7.1 字典 75 7.1.1 创建一个字典 75 7.1.2 使用Dictionary 类 78 7.2 散列表 79 7.2.1 创建一个散列表 79 7.2.2 使用HashTable 类 81 7.2.3 散列表和散列集合 82 7.2.4 处理散列表中的冲突 82 7.2.5 创建更好的散列函数 90 7.3 小结 91 第8 章 树 92 8.1 树的相关术语 92 8.2 二叉树和二叉搜索树 93 8.2.1 创建BinarySearchTree 类 94 8.2.2 向树中插入一个键 95 8.3 树的遍历 98 8.3.1 中序遍历 98 8.3.2 先序遍历 99 8.3.3 后序遍历 100 8.4 搜索树中的值 101 8.4.1 搜索最小值和最大值 101 8.4.2 搜索一个特定的值 103 8.4.3 移除一个节点 104 8.5 更多关于二叉树的知识 108 8.6 小结 109 第9 章 图 110 9.1 图的相关术语 110 9.2 图的表示 112 9.2.1 邻接矩阵 112 9.2.2 邻接表 113 9.2.3 关联矩阵 114 9.3 创建图类 114 9.4 图的遍历 116 9.4.1 广度优先搜索 117 9.4.2 深度优先搜索 122 9.5 小结 128 第10 章 排序和搜索算法 129 10.1 排序算法 129 10.1.1 冒泡排序 130 10.1.2 选择排序 133 10.1.3 插入排序 134 10.1.4 归并排序 135 10.1.5 快速排序 138 10.2 搜索算法 142 10.2.1 顺序搜索 143 10.2.2 二分搜索 143 10.3 小结 145 第11 章 算法补充知识 146 11.1 递归146 11.1.1 JavaScript 调用栈大小的 限制 147 11.1.2 斐波那契数列 147 11.2 动态规划 149 11.3 贪心算法 152 11.4 大O 表示法 153 11.4.1 理解大O 表示法 153 11.4.2 时间复杂度比较 155 11.5 用算法娱乐身心 156 11.6 小结 157 附录A 时间复杂度速查表 158 致谢 160

立即下载
学习JavaScript数据结构算法(超清 中英文版)

本书介绍了JavaScript语言的基础知识,适用于Web前端开发人员,以及所有对JavaScript数据结构和算法感兴趣的读者。文档包含了中英文版本,可以进行比对学习。

立即下载
数据结构算法 Python语言描述 裘宗燕 高清扫描

数据结构与算法 Python语言描述 高清扫描版pdf,带完整书签~ 【作 者】裘宗燕 编著 【出版发行】 北京:机械工业出版社 , 2016.01 【ISBN号】978-7-111-52118-1 【页 数】 346 【丛书名】面向CS2013计算机专业规划教材 【原书定价】45.00 【主题词】数据结构-高等学校-教材-算法分析-软件工具-程序设计 【中图法分类号】TP311.56;TP311.12 【内容提要】 本书基于Python语言介绍了数据结构与算法的基本知识,主要内容包括抽象数据类型和Python面向对象程序设计、线性表、字符串、栈和队列、二叉树和树、集合、排序以及算法的基本知识。本书延续问题求解的思路,从解决问题的目标来组织教学内容,注重理论与实践的并用。 【参考文献格式】裘宗燕编著. 数据结构与算法 Python语言描述. 北京:机械工业出版社, 2016.01

立即下载
数据结构算法JavaScript描述 完整版216页 PDF(含源码)

本书高清PDF 86M 收集自网络,请在资源下载后24H内删除,著作权归原书作者。如觉得图书非常有用,请自己购买纸质书籍。 《数据结构与算法JavaScript描述》 推荐序  XI 前言  XII 第1章 JavaScript的编程环境和模型  1 1.1 JavaScript环境  1 1.2 JavaScript编程实践  2 1.2.1 声明和初始化变量  3 1.2.2 JavaScript中的算术运算和数学库函数  3 1.2.3 判断结构  4 1.2.4 循环结构  6 1.2.5 函数  7 1.2.6 变量作用域  7 1.2.7 递归  9 1.3 对象和面向对象编程  10 1.4 小结  11 第2章 数组  13 2.1 JavaScript中对数组的定义  13 2.2 使用数组  13 2.2.1 创建数组  14 2.2.2 读写数组  15 2.2.3 由字符串生成数组  15 2.2.4 对数组的整体性操作  16 2.3 存取函数  17 2.3.1 查找元素  17 2.3.2 数组的字符串表示  18 2.3.3 由已有数组创建新数组  18 2.4 可变函数  19 2.4.1 为数组添加元素  19 2.4.2 从数组中删除元素  20 2.4.3 从数组中间位置添加和删除元素  21 2.4.4 为数组排序  21 2.5 迭代器方法  22 2.5.1 不生成新数组的迭代器方法  22 2.5.2 生成新数组的迭代器方法  25 2.6 二维和多维数组  27 2.6.1 创建二维数组  27 2.6.2 处理二维数组的元素  28 2.6.3 参差不齐的数组  29 2.7 对象数组  30 2.8 对象中的数组  31 2.9 练习  32 第3章 列表  33 3.1 列表的抽象数据类型定义  33 3.2 实现列表类  34 3.2.1 append:给列表添加元素  35 3.2.2 remove:从列表中删除元素  35 3.2.3 find:在列表中查找某一元素  35 3.2.4 length:列表中有多少个元素  36 3.2.5 toString:显示列表中的元素  36 3.2.6 insert:向列表中插入一个元素  37 3.2.7 clear:清空列表中所有的元素  37 3.2.8 contains:判断给定值是否在列表中  37 3.2.9 遍历列表  38 3.3 使用迭代器访问列表  39 3.4 一个基于列表的应用  40 3.4.1 读取文本文件  40 3.4.2 使用列表管理影碟租赁  41 3.5 练习  44 第4章 栈  45 4.1 对栈的操作  45 4.2 栈的实现  46 4.3 使用Stack类  48 4.3.1 数制间的相互转换  49 4.3.2 回文  50 4.3.3 递归演示  51 4.4 练习  52 第5章 队列  53 5.1 对队列的操作  53 5.2 一个用数组实现的队列  54 5.3 使用队列:方块舞的舞伴分配问题  57 5.4 使用队列对数据进行排序  61 5.5 优先队列  63 5.6 练习  65 第6章 链表  67 6.1 数组的缺点  67 6.2 定义链表  67 6.3 设计一个基于对象的链表  69 6.3.1 Node类  69 6.3.2 LinkedList类  69 6.3.3 插入新节点  69 6.3.4 从链表中删除一个节点  71 6.4 双向链表  74 6.5 循环链表  78 6.6 链表的其他方法  79 6.7 练习  79 第7章 字典  81 7.1 Dictionary类  81 7.2 Dictionary类的辅助方法  83 7.3 为Dictionary类添加排序功能  85 7.4 练习  86 第8章 散列  87 8.1 散列概览  87 8.2 HashTable类  88 8.2.1 选择一个散列函数  88 8.2.2 一个更好的散列函数  91 8.2.3 散列化整型键  93 8.2.4 对散列表排序、从散列表中取值  95 8.3 碰撞处理  96 8.3.1 开链法  96 8.3.2 线性探测法  99 8.4 练习  100 第9章 集合  101 9.1 集合的定义、操作和属性  101 9.1.1 集合的定义  101 9.1.2 对集合的操作  102 9.2 Set类的实现  102 9.3 更多集合操作  104 9.4 练习  107 第10章 二叉树和二叉查找树  109 10.1 树的定义  109 10.2 二叉树和二叉查找树  111 10.2.1 实现二叉查找树  111 10.2.2 遍历二叉查找树  113 10.3 在二叉查找树上进行查找  116 10.3.1 查找最小值和最大值  116 10.3.2 查找给定值  117 10.4 从二叉查找树上删除节点  118 10.5 计数  120 10.6 练习  123 第11章 图和图算法  125 11.1 图的定义  125 11.2 用图对现实中的系统建模  127 11.3 图类  127 11.3.1 表示顶点  127 11.3.2 表示边  127 11.3.3 构建图  128 11.4 搜索图  130 11.4.1 深度优先搜索  130 11.4.2 广度优先搜索  133 11.5 查找最短路径  135 11.5.1 广度优先搜索对应的最短路径  135 11.5.2 确定路径  135 11.6 拓扑排序  137 11.6.1 拓扑排序算法  137 11.6.2 实现拓扑排序算法  137 11.7 练习  141 第12章 排序算法  143 12.1 数组测试平台  143 12.2 基本排序算法  145 12.2.1 冒泡排序  145 12.2.2 选择排序  148 12.2.3 插入排序  150 12.2.4 基本排序算法的计时比较  151 12.3 高级排序算法  153 12.3.1 希尔排序  153 12.3.2 归并排序  158 12.3.3 快速排序  163 12.4 练习  167 第13章 检索算法  169 13.1 顺序查找  169 13.1.1 查找最小值和最大值  172 13.1.2 使用自组织数据  175 13.2 二分查找算法  177 13.3 查找文本数据  183 13.4 练习  185 第14章 高级算法  187 14.1 动态规划  187 14.1.1 动态规划实例:计算斐波那契数列  188 14.1.2 寻找最长公共子串  191 14.1.3 背包问题:递归解决方案  194 14.1.4 背包问题:动态规划方案  195 14.2 贪心算法  196 14.2.1 第一个贪心算法案例:找零问题  196 14.2.2 背包问题的贪心算法解决方案  197 14.3 练习  199 封面介绍  200

立即下载
JavaScript高级程序设计+JavaScript权威指南第4版 带目录扫描

JavaScript高级程序设计+JavaScript权威指南第4版 带目录 非扫描

立即下载
关闭
img

spring mvc+mybatis+mysql+maven+bootstrap 整合实现增删查改简单实例.zip

资源所需积分/C币 当前拥有积分 当前拥有C币
5 0 0
点击完成任务获取下载码
输入下载码
为了良好体验,不建议使用迅雷下载
img

数据结构与算法JavaScript描述 超清 非扫描 有目录

会员到期时间: 剩余下载个数: 剩余C币: 剩余积分:0
为了良好体验,不建议使用迅雷下载
VIP下载
您今日下载次数已达上限(为了良好下载体验及使用,每位用户24小时之内最多可下载20个资源)

积分不足!

资源所需积分/C币 当前拥有积分
您可以选择
开通VIP
4000万
程序员的必选
600万
绿色安全资源
现在开通
立省522元
或者
购买C币兑换积分 C币抽奖
img

资源所需积分/C币 当前拥有积分 当前拥有C币
5 4 45
为了良好体验,不建议使用迅雷下载
确认下载
img

资源所需积分/C币 当前拥有积分 当前拥有C币
5 0 0
为了良好体验,不建议使用迅雷下载
VIP和C币套餐优惠
img

资源所需积分/C币 当前拥有积分 当前拥有C币
5 4 45
您的积分不足,将扣除 10 C币
为了良好体验,不建议使用迅雷下载
确认下载
下载
您还未下载过该资源
无法举报自己的资源

兑换成功

你当前的下载分为234开始下载资源
你还不是VIP会员
开通VIP会员权限,免积分下载
立即开通

你下载资源过于频繁,请输入验证码

您因违反CSDN下载频道规则而被锁定帐户,如有疑问,请联络:webmaster@csdn.net!

举报

若举报审核通过,可返还被扣除的积分

  • 举报人:
  • 被举报人:
  • *类型:
    • *投诉人姓名:
    • *投诉人联系方式:
    • *版权证明:
  • *详细原因: