js---描述链表】的更多相关文章

(js描述的)数据结构 [链表](4) 一.基本结构 二.想比于数组,链表的一些优点 1.内存空间不是必须连续的,可以充分利用计算机的内存,事项灵活的内存动态管理. 2.链表不必再创建时就确定大小,并且大小可无限的延申下去 3.链表再插入和删除数据时,比数组的效率高很多 三.相比于数组,链表的一些缺点 1.链表访问任何一个位置的元素时,都需要从头开始访问 2.无法通过下标直接访问元素,需要从头开始访问,直到找到对应的元素 四.链表的封装 // 封装链表类 function LinkedList(…
(js描述的)数据结构[哈希表1.1](8) 一.数组的缺点 1.数组进行插入操作时,效率比较低. 2.数组基于索引去查找的操作效率非常高,基于内容去查找效率很低. 3.数组进行删除操作,效率也不高. 二.哈希表 1.几乎所有的编程语言都有直接或间接的应用这种数据结构 2.哈希表是基于 数组 实现的,但相对于数组有很多优势. 1.它可以提供非常快速的 插入-删除-查找 操作 2.无论多少数据,插入和删除需要接近常量的时间.即O(1)的时间级 3.哈希表的速度比树还要快,基本可以瞬间找到想要的元素…
(js描述的)数据结构[双向链表](5) 一.单向链表的缺点 1.只能按顺序查找,即从上一个到下一个,不能反过来. 二.双向链表的优点 1.可以双向查找 三.双向链表的缺点 1.结构较单向链表复杂. 2.占用内存比单项链表多. 四.双向链表的结构 五.双向链表的代码实现 function DoublyLinkedList() { // 内部节点类 function Node(data) { this.data = data this.next = null this.prev = null }…
(js描述的)数据结构 [数组的一些补充](1) 1. js的数组: 1.优点:高度封装,对于数组的操作就是调用API 2.普通语言的数组: 1.优点:根据index来查询,修改数据效率很高 2.缺点: *普通的数组不支持存放不同的数据类型,所以在对普通数组进行封装的时候一般用对象(例如: java ArrayList). *普通数组的删除,中间插入等操作效率很低. *普通的数组不支持扩容,即申请多少大小的数组数组的大小就不可改变,所以封装的思路就是重新申请一个新数组,把原数组的值再拷贝进去.…
js描述集合 function Set(){ this.datasource=[]; this.add=add; this.remove=remove; //this.size=size; //this.union=union; //this.intersect=intersect; //this.subset=subset; //this.difference=difference; this.show=show; } function add(data){ if(this.datasourc…
js描述队列 队列的特性是只能在队尾插入元素,在队首删除元素,先进先出: 队列被用在很多地方,比如提交操作系统执行的一系列进程,打印任务池,模拟现实中的排队: //队列类 function Queue (){ this.dataSource=[]; this.enqueue=enqueue; this.dequeue=dequeue; this.front=front; this.back=back; this.toString=toString; this.empty=empty; } //向…
js描述栈及栈的使用 栈的特性就是只能通过一端访问,这一段就是叫做栈顶.咖啡馆内的一摞盘子就是最形象的栈的例子: 根据栈的特性,就可以定义栈的一些特殊属性和方法;用js的描述栈的时候底层数据结构用的是数组,通过this.top来跟踪最后一个元素的索引来实现栈的数据结构: function Stack(){ this.dataSource=[]; this.top=0; this.push=push; this.pop=pop; this.peek=peek; this.clear=clear;…
(js描述的)数据结构[字典](7) 一.字典的特点 1.字典的主要特点是一一对应关系. 2.使用字典,剋通过key取出对应的value值. 3.字典中的key是不允许重复的,而value值是可以重复,并且字典中的key是无序的. 字典和映射关系: 字典和数组: 字典和对象: 二.代码实现字典 function Dictionary() { this.dic = {} // 1. add方法 Dictionary.prototype.add = function(key, value) { th…
(js描述的)数据结构[集合结构](6) 一.集合结构特点 1.集合中的元素不能重复. 2.集合是无序的. 二.集合的代码实现 function Set() { this.items = {} //1. add方法 Set.prototype.add = function(value) { //判断集合中是否包含元素 if (this.has(value)) { return false } //把数据添加到集合中 this.items[value] = value return true }…
(js描述的)数据结构[队列结构](3) 一.队列结构的特点: 1.基于数组来实现,的一种受限的线性结构. 2.只允许在表头进行删除操作,在表尾进行插入操作. 3.先进先出(FIFO) 二.队列的一些应用: 1.按一定顺序打印文档,执行输出后的结果. 2.多线程的实际执行顺序,就如队列结构相似. 三.队列的封装: function Queue() { this.items = [] //向队尾添加一个元素 Queue.prototype.enqueue = function (element)…