zoukankan      html  css  js  c++  java
  • 链表

    Node.js自定义链表

    链表(Linked list)是一种常见的基础数据结构,是一种线性表,但是不像顺序表一样连续存储数据,而是每一个结点(数据存储单元)里存放下一个结点的信息(即地址)

    方法介绍:

    . is_empty():链表是否为空
    
    . length():链表长度
    
    . travel():遍历整个链表
    
    . add(item):链表头部添加元素
    
    . append(item):链表尾部添加元素
    
    . insert(pos, item):指定位置添加元素
    
    . remove(item):删除节点
    
    . search(item):查找节点是否存在
    
    . reverse():  链表倒置
    

    代码:

    class Node {
        // 节点
        constructor(item) {
            this.item = item
            this.next = null
        }
    }
    
    
    class Link {
        // 链表
        constructor() {
            this._head = null
        }
    
        add(item) {
            // 添加元素
            let node = new Node(item)
            node.next = this._head
            this._head = node
        }
    
        travel() {
            // 遍历
            let cur = this._head
            while (cur) {
                console.log(cur.item)
                cur = cur.next
            }
        }
    
        isEmpty() {
            return this._head === null
        }
    
        length() {
            // 长度
            let count = 0
            let cur = this._head
            while (cur) {
                count += 1
                cur = cur.next
            }
            return count
        }
    
        append(item) {
            // 向链尾添加元素
            let node = new Node(item)
            if (this._head === null) {
                this._head = node
                return
            }
    
            let pre = null
            let cur = this._head
            while (cur) {
                pre = cur
                cur = cur.next
            }
            // 当while循环结束的时候,pre就指向了链表中最后一个节点
            pre.next = node
        }
    
        insert(pos, item) {
            // 将item对应的节点插入到pos指定的位置中
            let node = new Node(item)
            if (pos === 0) {
                node.next = this._head
                this._head = node
                return
            }
    
            let cur = this._head
            let pre = null
            for (let i = 0; i < pos; i++) {
                pre = cur
                cur = cur.next
            }
    
            pre.next = node
            node.next = cur
    
        }
    
        remove(item) {
            // 删除节点
            if (this._head && this._head.item === item) {
                this._head = this._head.next
                return
            }
    
            let cur = this._head
            let pre = null
            while (cur) {
                pre = cur
                cur = cur.next
                if (cur.item === item) {
                    pre.next = cur.next
                    return;
                }
            }
    
        }
    
        search(item) {
            // 查询某个节点是否存在
            let cur = this._head
            while (cur) {
                if (cur.item === item) {
                    return true
                }
                cur = cur.next
            }
            return false
        }
    
        reverse() {
            // 链表倒置
            let pre = this._head
            let cur = pre.next
            let next_node = cur.next
    
            pre.next = null  // 链表倒置后pre就是最后一个节点,最后一个节点的next指向None
    
            while (1) {
                cur.next = pre
                pre = cur
                cur = next_node
    
                if (next_node !== null) {
                    next_node = next_node.next
                } else {
                    break
                }
            }
    
            this._head = pre
    
        }
    
    }
    
    link = new Link()
    link.add(1)
    link.add(2)
    link.add(3)
    link.add(4)
    link.add(5)
    link.insert(0, 0)
    link.remove(0)
    link.reverse()
    link.travel()
    console.log(link.isEmpty())
    console.log(link.length())
    
    
  • 相关阅读:
    ByteArrayOutputStream的用法
    Oracle字符函数(转换大小写,替换等)
    Linux 结束占用端口的程序
    堆是先进先出,栈是先进后出
    帮小黎解决问题C++巩固获得数字每个位置上的数
    负数的二进制表示方法
    为什么1Byte=8bit
    黎活明给程序员的忠告
    寻找最好的编程语言
    U盘启动时无USB-HDD选项的解决方案
  • 原文地址:https://www.cnblogs.com/ghh520/p/15068410.html
Copyright © 2011-2022 走看看