JavaScript实现循环链表
2019-01-23 07:40:41来源:博客园 阅读 ()
单链表地址:点我
一、循环链表
节点的next指向下一个节点,节点的prev指向上一个节点
function loopList() { let length = 0, head = null, tail = null this.append = (data) => { let node = new Node(data), current if(head === null) { head = node tail = node }else { current = head while(current.next) { current = current.next } current.next = node tail = node } length ++ return true } this.insert = (position, data) => { if(position > -1 && position <= length) { let node = new Node(data), current = head, previous if(position === 0) { if (!head) { head = node tail = node }else { node.next = current current.prev = node head = node } } else if(position === length) { current = tail current.next = node node.prev = current tail = node } else { while(index ++ < position) { previous = current current = current.next } previous.next = node node.prev = previous node.next = current current.prev = node } length ++ return true }else { return false } } this.removePos = function (position) { //检查是否越界 if (position > -1 && position < length) { var current = head, previous, index = 0 if (position === 0) { //移除第一项 head = current.next if (length === 1) { tail = null }else { head.prev = null } }else if(position === length - 1) { current = tail tail = current.prev tail.next = null }else { while (index++ < position) { previous = current current = current.next } //将previous与current的下一项链接起来,跳过current,从而移除它 previous.next = current.next current.next.prev = previous } length -- return true }else { return false } } this.removeData = (data) => { if(head === null) { return false } else { let current = head, previous, index = 0 if (length === 1 ) { if (current.data !== data) { return false }else { head = null tail = null length -- return true } } while (index ++ < length && current.data !== data) { previous = current current = current.next } if(index === length) { current = tail tail = current.prev tail.next = null length -- return true } if(index > length) { return false }else { previous.next = current.next current.next.prev = previous length -- return true } } } this.toString = () => { let resultStr = "", current, index = length if(head === null) { return "" }else { current = head while(index -- > 0) { resultStr += "," + current.data current = current.next } return resultStr.slice(1) } } } function Node(data) { this.data = data this.next = null this.prev = null }
原文链接:https://www.cnblogs.com/detanx/p/JavaScriptloopList.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- javascript面向对象入门基础详细介绍 2020-03-29
- js防止表单重复提交实现代码 2020-03-29
- 基于JQuery的多标签实现代码 2020-03-29
- js实现翻页后保持checkbox选中状态的实现方法 2020-03-25
- JavaScript函数表达式详解及实例 2020-03-25
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash