数据结构篇(2) ts实现单链表
interface NodeItem {
prev: NodeItem | null
next: NodeItem | null
data: any
}
class NodeItem {
prev: NodeItem | null = null
next: NodeItem | null = null
constructor(data: any) {
this.data = data ? data : null;
}
}
interface ListNode {
head: any
size: number
currentNode: NodeItem | null
find(item:any):NodeItem | null // 在单链表中寻找item元素
insert(element:any,item:any):void // 向单链表中插入元素
remove(item:any):void // 在单链表中删除一个节点
append(element:any):void // 在单链表的尾部添加元素
findLast():NodeItem // 获取单链表的最后一个节点
isEmpty():boolean // 判断单链表是否为空
show():void // 显示当前节点
getLength():number // 获取单链表的长度
advance(n:number, currNode:NodeItem):void // 从当前节点向前移动n个位置
display():void // 单链表的遍历显示
clear():void // 清空单链表
}
class ListNode {
head: any = null
size: number = 0
currentNode: NodeItem | null = null
constructor() {
this.head = new NodeItem('head');
}
find(item:any):NodeItem | null {
let currNode = this.head;
while(currNode) {
if(currNode.data === item) {
return currNode;
}
currNode = currNode.next;
}
return null;
}
insert(element:any,item:any):any {
if(!this.find(element)) {
return;
}
let prevNode = this.find(element);
if(prevNode == null) {
return ;
}
let currNode = new NodeItem(item);
currNode.next = prevNode.next;
prevNode.next = currNode;
this.size++;
}
remove(item:any):void {
if(!this.find(item)) {
return ;
}
if(item === 'head') {
if(!this.isEmpty()) {
return ;
} else {
this.head.next = null;
return;
}
}
let currNode = this.head;
while(currNode) {
if(currNode&&currNode.next.data === item) {
break;
}
currNode = currNode.next;
}
currNode.next = currNode.next.next;
this.size--;
}
append(element:any):void {
let rear = this.findLast();
let currentNode = new NodeItem(element);
rear.next = currentNode;
this.size++;
}
findLast():NodeItem {
let currNode:NodeItem = this.head;
while(currNode.next) {
currNode = currNode.next;
}
return currNode;
}
isEmpty():boolean {
if(this.head.next) {
return true;
}
return false;
}
show():void {
console.log(this.currentNode?.data);
}
getLength():number {
let i = 0;
let currNode = this.head;
while(currNode) {
i++;
currNode = currNode.next;
}
return i;
}
advance(n:number, currNode:NodeItem = this.head):NodeItem {
this.currentNode = currNode;
while((n--)&&this.currentNode.next) {
this.currentNode = this.currentNode?.next;
}
return this.currentNode;
}
display():void {
let currentNode = this.head;
while(currentNode) {
console.log(currentNode.data);
currentNode = currentNode.next;
}
}
clear():void {
this.head.next = null;
this.size = 0;
}
}
let myList = new ListNode();
let arr = [3, 4, 5, 6, 7, 8, 9];
for(let i=0; i<arr.length; i++){
myList.append(arr[i]);
}
myList.insert(3,2);
myList.display();
数据结构篇(2) ts实现单链表的更多相关文章
- 数据结构篇(2) ts实现单循环链表
JS的class可以通过extends关键字实现类似其他语言的继承效果,比起使用一个extends关键字,在es5中实现继承要复杂一些,可以通过修改原型链的方法实现继承,让一个原型对象等于另一个类型的 ...
- 新秀nginx源代码分析数据结构篇(两) 双链表ngx_queue_t
nginx源代码分析数据结构篇(两) 双链表ngx_queue_t Author:Echo Chen(陈斌) Email:chenb19870707@gmail.com Blog:Blog.csdn. ...
- 菜鸟nginx源代码剖析数据结构篇(八) 缓冲区链表ngx_chain_t
菜鸟nginx源代码剖析数据结构篇(八) 缓冲区链表 ngx_chain_t Author:Echo Chen(陈斌) Email:chenb19870707@gmail.com Blog:Blog. ...
- 菜鸟nginx源码剖析数据结构篇(八) 缓冲区链表ngx_chain_t[转]
菜鸟nginx源码剖析数据结构篇(八) 缓冲区链表 ngx_chain_t Author:Echo Chen(陈斌) Email:chenb19870707@gmail.com Blog:Blog.c ...
- 菜鸟nginx源码剖析数据结构篇(三) 单向链表 ngx_list_t[转]
菜鸟nginx源码剖析数据结构篇(三) 单向链表 ngx_list_t Author:Echo Chen(陈斌) Email:chenb19870707@gmail.com Blog:Blog.csd ...
- 数据结构篇(3)ts 实现双向链表
如今终于到了双向链表了,此前在Node结构中的prev指针终于派上了用场.由于双向链表多了一个前向指针,所以有些操作和单向链表比较起来反而更加的简单. class DbList extends Cir ...
- 数据结构篇(1) ts实现栈的基本操作和解决相关问题
interface Stack { _items: any push(element: any): void pop(): any top(): any size(): any isEmpty(): ...
- 图解Redis之数据结构篇——链表
前言 Redis链表为双向无环链表! 图解Redis之数据结构篇--简单动态字符串SDS提到Redis使用了简单动态字符串,链表,字典(散列表),跳跃表,整数集合,压缩列表这些数据结构 ...
- C语言实现的单链表
链表是一种线性表,但是并不是顺序存储,而是每个节点里面存储着下一个节点的指针,把存储数据元素的数据串链起来. 单链表的基本实现: typedef int DataType;//定义单链表typedef ...
随机推荐
- C++ 关于map,function的简单应用
map<string,function<int(int, int)>> funs = { {"+", add}, {&qu ...
- 你在项目中哪些地方用到了 XML?
XML 的主要作用有两个方面:数据交换和信息配置.在做数据交换时,XML 将数 据用标签组装成起来,然后压缩打包加密后通过网络传送给接收者,接收解密与 解压缩后再从 XML 文件中还原相关信息进行处理 ...
- tcp粘包问题原因及解决办法
1.粘包概念及产生原因 1.1粘包概念: TCP粘包是指发送方发送的若干包数据到接收方接收时粘成一包,从接收缓冲区看,后一包数据的头紧接着前一包数据的尾. 粘包可能由发送方造成,也可能由接收方造成. ...
- Mybatis 开发 dao 的方法
1.分析SqlSession使用范围 1.1.SqlSessionFactoryBuilder 通过 SqlSessionFactoryBuilder 创建会话工厂 SqlSessionFactory ...
- Python - 本地文件读写(初级)
- (stm32学习总结)—对寄存器的理解
芯片里面有什么 我们看到的 STM32 芯片是已经封装好的成品,主要由内核和片上外设组成.若与电脑类比,内核与外设就如同电脑上的 CPU 与主板.内存.显卡.硬盘的关系.STM32F103 采用的是 ...
- IPhoneX网页布局简介
IPhoneX全面屏是十分科技化的,但是由于其圆角和摄像头刘海位置以及操控黑条的存在使得我们需要去对其样式做一些适配,没有X的同学可以开启 Xcode 9 的iPhone X 模拟器作为学习和调试. ...
- zTree -- jQuery 树插件 使用方法与例子
简介 zTree 是一个依靠 jQuery 实现的多功能 "树插件". 网址:http://www.ztree.me/v3/main.php#_zTreeInfo 上面的网址里有z ...
- html 不常用标签介绍
文本元素 <wbr> 如果单词太长,或者您担心浏览器会在错误的位置换行,那么您可以使用 <wbr> 元素来添加 Word Break Opportunity(单词换行时机).英 ...
- 纯JS实现KeyboardNav(学习笔记)二
纯JS实现KeyboardNav(学习笔记)二 这篇博客只是自己的学习笔记,供日后复习所用,没有经过精心排版,也没有按逻辑编写 这篇主要是添加css,优化js编写逻辑和代码排版 GitHub项目源码 ...