首页 技术 正文
技术 2022年11月6日
0 收藏 582 点赞 603 浏览 5183 个字

关于链表简介、单链表、单向循环链表、JS中的使用以及扩充方法:  单链表、循环链表的JS实现

关于四种链表的完整封装: https://github.com/zhuwq585/Data-Structure-in-JavaScript/blob/master/LinkedList.js

双向链表:单向链表只能向着一个方向遍历链表节点,而在节点指针域中增加了前向指针的双向链表,则可以向着两个方向遍历节点。这使得双向链表也可以在任何一个节点遍历整个链表。

function DoublyLinkedList() {
var Node = function(element) {
this.element = element;
this.next = null;
this.prev = null;
};var length = 0,
head = null,
tail = null;this.append = function(element){
var node = Node(element),
current,
previous;if(!head){
head = node;
tail = node;
}else{
current = head;
while(current){
previous = current;
current = current.next;
}node.next = current;
current.prev = node;
previous.next = node;
node.prev = previous;
}length++;
return true;
}this.insert = function(position,element){
if(position > -1 && position < length){
var node = new Node(element),
current = head,
previous,
index = 0;if(position === 0){if(!head){
head = node;
tail = node;
}else{
node.next = current;
current.prev = node;
head = node;
}}else if (position === length -1){
current = tail;
current.next = node;
node.prev = current;
}else {
while(index++ < position){
previous = current;
current = current.next;
}
node.next = current;
previous.next = node;
current.prev = node;
node.prev = previous;
}length++;
return true;
}else{
return false;
}
};this.removeAt = function(position){
if(position > -1 && position < length){
var current = head,
index = 0,
previous;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.next = current.next;
current.next.prev = previous;
};
length-- ;return current.element;
}else{
return false;
}
};this.remove = function(element){
var current = head,
previous;if(current.element === element){
head = current.next;
}
previous = current;
current = current.next;while(current){
if (current.element = element) {
previous.next = current.next;
current.next.prev = previous;
}else{
previous = current;
current = current.next;
}
}
return false;
};this.remove = function(){
if (length === 0) {
return false;
};var current = head,
previous;if(length === 1){
head = null;
tail = null;
length--;
return current.element;
}while(current){
previous = current;
current = current.next;
}previous.next = null;
length--;
return current.element;
};this.indexOf = function(element){
var current = head,
index = 0;while(current && index++ < length){
if (current.element === element) {
return index;
};
current = current.next;
}return false;
};this.isEmpty = function(){
return length === 0;
};this.size = function(){
return length;
};this.toString = function(){
var current = head,
string = '';while(current){
string += current.element;
current = current.next;
}
return string;
};this.getHead = function(){
return head;
};this.getTail = function(){
return tail;
};
}

双向循环链表:将双向链表的头尾指针相连,就构成了双向循环链表。这种链表从任意一个节点都可以同时向两个方向进行节点遍历,查询节点的速度也是最快的。

/*双向循环链表*/
function DoublyCircularLinkedList(){
var Node = function(element){
this.element = element;
this.next = null;
this.prev = null;
};var length = 0,
head = null,
tail = null;this.append = function(element){
var node = new Node(element),
current,
previous;if (!head) {
head = node;
tail = node;
head.prev = tail;
tail.next = head;
}else{
current = head;while(current.next !== head){
previous = current;
current = current.next;
}current.next = node;
node.next = head;
node.prev = current;
};length++;
return true;
};this.insert = function(position, element){
if(position >= 0 && position <= length){
var node = new Node(element),
index = 0,
current = head,
previous;if(position === 0){if(!head){node.next = node;
node.tail = node;
head = node;
tail = node;}else{current.prev = node;
node.next = current;
head = node;
node.prev = tail;}}else if(position === length){
current = tail;current.next = node;
node.prev = current;
tail = node;
node.next = head;
}else{while(index++ < position){
previous = current;
current = current.next;
}current.prev = node;
node.next = current;
previous.next = node;
node.prev = previous;}length++;
return true;
}else{
return false;
}
};this.removeAt = function(position){
if(position > -1 && position < length){var current = head,
index = 0,
previous;if(position === 0){current.next.previous = tail;
head = current.next;}else if(position === length - 1){current = tail;current.prev.next = head;
head.prev = current.prev;
tail = current.prev;
}else{while(index++ < position){
previous = current;
current = current.next;
}previous.next = current.next;
current.next.prev = previous;}length--;
return true;
}else{
return false;
}
};this.remove = function(element){
var current = head,
previous,
indexCheck = 0;while(current && indexCheck < length){
if(current.element === element){
if(indexCheck === 0){
current.next.prev = tail;
head = current.next;
}else{
current.next.prev = previous;
previous.next = current.next;
}
length--;
return true;
}previous = current;
current = current.next;
indexCheck++;
}return false;
};this.remove = function(){
if(length === 0){
return false;
}var current = head,
previous,
indexCheck = 0;if(length === 1){
head = null;
tail = null;
length--;
return current.element;
}while(indexCheck++ < length){
previous = current;
current = current.next;
}previous.next = head;
tail = previous.next;
length--;
return current.element;
};this.indexOf = function(element){
var current = head,
index = 0;while(current && index++ < length){
if(current.element === element){
return index;
}
current = current.next;
}return false;
};this.toString = function(){
var current = head,
indexCheck = 0,
string = '';while(current && indexCheck < length){
string += current.element;
indexCheck++;
current = current.next;
}return string;
};this.isEmpty = function(){
return length === 0;
};this.getHead = function(){
return head;
};this.getTail = function(){
return tail;
};this.size = function(){
return length;
};
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,023
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,513
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,361
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,143
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,774
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,853