实现简易版——MyLinkedList

2023-11-01

在这里插入图片描述

class Node{
    String val;
    Node pre;  //双向
    Node next;
    Node(String val){
        this.val = val;
    }
}
public class MyLinkedList {
    private Node head;  //头结点
    private Node last;  //尾结点
    private int size;   //链表中当前元素个数
    public boolean add(String e){
        //将元素装到结点对象中
        Node node = new Node(e);
        if(head == null){
            head = last = node;
        }else{
            node.pre = last;
            last.next = node;
            last = node;
        }
        size++;
        return true;
    }

    public void add(int index,String e){
        //判断是否是合法下标
        if(index < 0 || index > size()){
            throw new IndexOutOfBoundsException("下标越界"+index);
        }
        Node node = new Node(e);
        if(head == null){
            head = last = node;
        }else if(index == 0){
            node.next = head;
            head.pre = node;
            head = node;
        }else if(index == size()){
            last.next = node;
            node.pre = last;
            last = node;
        }else{
            //需要得到index处结点
            Node cur = getNodeByIndex(index);
            Node pre = cur.pre;
            pre.next = node;
            node.next = cur;
            node.pre = pre;
            cur.pre = node;
        }
        size++;
    }

    private Node getNodeByIndex(int index){
        Node cur = head;
        for(int i = 0;i < index;i++){
            cur = cur.next;
        }
        return cur;
    }

    public String remove(int index){
        //判断是否是合法下标
        if(index < 0 || index >= size()){
            throw new IndexOutOfBoundsException("下标越界"+index);
        }
        String v = null;
        if(size() == 1){
            v = head.val;
            head = last = null;
        }else if(index == 0){
            v = head.val;
            head = head.next;
            head.pre = null;
        }else if(index == size()-1){
            v = last.val;
            last = last.pre;
            last.next = null;
        }else{
            Node cur = getNodeByIndex(index);
            v = cur.val;
            Node pre = cur.pre;
            Node next = cur.next;
            pre.next = next;
            next.pre = pre;
        }
        size--;
        return v;
    }

    public boolean remove(String e){
        Node cur = head;
        while(cur != null){
            if(cur.val.equals(e)){
                Node pre = cur.pre;
                Node next = cur.next;
                if(pre == null){
                    //删除的是头结点
                   head = head.next;
                }else{
                    pre.next = next;
                }
                if(next == null){
                    last = last.pre;
                }else{
                    next.pre = pre;
                }
                size--;
                return true;
            }
        }
        return false;
    }
    
    public int size(){
        return size;
    }

    public String get(int index){
        //判断是否是合法下标
        if(index < 0 || index >= size()){
            throw new IndexOutOfBoundsException("下标越界"+index);
        }
        Node cur = head;
        for(int i = 0;i < index;i++){
            cur = cur.next;
        }
        return cur.val;
    }

    public String set(int index,String e){
        //判断是否是合法下标
        if(index < 0 || index >= size()){
            throw new IndexOutOfBoundsException("下标越界"+index);
        }
        Node node = head;
        for(int i = 0;i < index;i++){
            node = node.next;
        }
        String oldVal = node.val;
        node.val = e;
        return oldVal;
    }

    public boolean contains(String e){
        return indexOf(e) != -1;
    }

    public int indexOf(String e){
        Node cur = head;
        for(int i = 0;i < size();i++){
            if(cur.val.equals(e)){
                return i;
            }
            cur = cur.next;
        }
        return -1;
    }

    public int lastIndexOf(String e){
        //从后往前遍历,第一次遇到指定的元素即为正向遍历最后一次遇到指定元素
        Node cur = last;
        for(int i = size()-1;i >= 0;i--){
            if(cur.val.equals(e)){
                return i;
            }
            cur = cur.pre;
        }
        return -1;
    }

    public boolean isEmpty(){
        return size() == 0;
    }
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

实现简易版——MyLinkedList 的相关文章

  • 强化学习算法 Sarsa 解迷宫游戏,代码逐条详解

    本文内容源自百度强化学习 7 日入门课程学习整理 感谢百度 PARL 团队李科浇老师的课程讲解 强化学习算法 Sarsa 解迷宫游戏 文章目录 一 安装依赖库 二 导入依赖库 三 智能体 Agent 的算法 Sarsa 四 训练和测试语句

随机推荐

  • JVM面试问题系列:7种JVM垃圾收集器特点,优劣势、及使用场景!

    一 常见垃圾收集器 现在常见的垃圾收集器有如下几种 新生代收集器 Serial ParNew Parallel Scavenge 老年代收集器 Serial Old CMS Parallel Old 堆内存垃圾收集器 G1 每种垃圾收集器之
  • git credential manager for windows解决方法

    git credential manager for windows解决方法 一 保存 git 的密码 gitconfig 文件中添加 credential helper store 或者在git bash 中执行 git config g
  • 手写算法-FIFO

    一 思路 FIFO是英文First In First Out 的缩写 是一种先进先出的数据缓存器 他与普通存储器的区别是没有外部读写地址线 这样使用起来非常简单 但缺点就是只能顺序写入数据 顺序的读出数据 其数据地址由内部读写指针自动加1完
  • 什么是字节流?Java 中有哪些字节流

    在 Java 中 字节流是一种输入和输出数据的方式 它以字节为单位进行操作 字节流主要用于处理二进制数据 如图像 音频和视频等 在本文中 我们将介绍什么是字节流 Java 中的字节流有哪些以及一些示例代码 什么是字节流 字节流是输入和输出数
  • vue devtools安装及使用

    vue devtools使用 在vue学习开发之前 应安装vue devtools为我们提供一个界面 用来查看vue组件和全局状态管理器vuex中记录的数据 如果你可以访问google web store 请在store中安装 git cl
  • 解决:IDEA不能识别*.js文件

    在进行IDEA进行前端开发时 必不可少的会用到JavaScripts 在进行 js文件时 发现其不识别 为文本样式 如下图所示 Setting gt Editor gt File Types gt JavaScript gt 填写 js 这
  • ethers不同版本返回余额的整数值类型,以及对大整数值的处理差异性的比较

    目录 一 安装6v版本 二 安装5v版本 三 ethers 5v版本 1 获取余额 2 对于数值的处理
  • host command not found,host命令不可用的问题

    如果出现host command not found host命令不可用的问题 如果在centos环境下使用yum install bind utils进行安装bind utils的软件包 如果是unbuntu环境下可以使用sudo apt
  • Keil5编译——Error: L6218E: Undefined symbol

    1 具体问题 在初学RTThread着手最基础的 动态内存分配线程来控制LED闪烁 keil5编译时遇到以下的错误提示 STM32L431RC BearPiLED STM32L431RC BearPiLED axf Error L6218E
  • 今天软件开发面临的挑战

    1 开发模式的进化 2 软件工程意识的觉醒 3 软件过程的可视化管理 4 团队开发与合作 5 可重用性 可维护性和灵活性 6 质量控制和成本控制 7 加快上市时间 8 提高竞争优势
  • 街霸五显示登录服务器,pc版的街霸五如何登陆服务器

    发布时间 2016 03 27 Bungie与动视合作的首款FPS大作正式版将与9与9日登陆PS4和Xbox One PC版何在 动视目前已经确认PC版的正在制作中 但是动视并未透露详细的上市日期 不过已经有细心 标签 游戏资讯 游戏新闻
  • 窗函数设计FIR滤波器

    文章目录 实验原理 常见的窗函数 矩形窗Boxcar 巴特利特窗Bartlett 汉宁窗Hanning 哈明窗Hamming 布莱克曼窗Blackman 凯泽窗Kaiser 设计步骤 MATLAB实现 实验原理 有限单位冲激响应序列 h n
  • CV计算机视觉核心03-初步认识机器学习(线性回归模型、梯度下降法、线性回归模型解决数字识别问题(没用auto grad)、逻辑回归模型sigmoid、作业:线性回归解决数字识别auto grad)

    CV计算机视觉核心03 初步认识机器学习 线性回归模型 梯度下降法 区分一下回归模型和分类模型 线性回归模型解决数字识别问题 没有使用auto grad 逻辑回归模型 sigmoid函数 如何使用自动梯度计算 auto grad使用的注意事
  • SPEOS—光学产品设计及仿真工具

    SPEOS是ANSYS公司功能强大的光学仿真软件 用于光学设计 环境与视觉模拟 成像仿真等 强大的解决方案提供了可视化光学系统和直观的人机交互平台 其仿真技术已广泛用于汽车 电子电器 精密仪器 照明设备等领域 SPEOS软件内嵌ISO和CI
  • 01趣味算法 ---- 走进算法

    14天阅读挑战赛 努力是为了不平庸 算法学习有些时候是枯燥的 这一次 让我们先人一步 趣学算法 欢迎记录下你的那些努力时刻 算法学习知识点 算法题解 遇到的算法bug 等等 在分享的同时加深对于算法的理解 同时吸收他人的奇思妙想 一起见证技
  • go语言结构体与JSON序列化

    JSON JavaScript Object Notation 是一种轻量级的数据交换格式 易于人阅读和编写 同时也易于机器解析和生成 JSON键值对是用来保存JS对象的一种方式 键 值对组合中的键名写在前面并用双引号 包裹 使用冒号 分隔
  • Linux笔记_4(群组和文件目录属性)

    Linux笔记 4 标签 空格分隔 Linux 使用者与群组 1 在Linux里面 每个档案都有 Users Group Others 三种身份的权限 a 档案拥有者 b 群组 每个账号可以在多个群组中 c 其他人 2 预设情况下 系统上所
  • Word临时文件怎么恢复?可持续的文件恢复方法

    在word进行文档编辑时 有时候会发生误删除word文件的情况 这个时候word临时文件怎么恢复呢 其实word临时文件还存在于电脑中 本篇文章就来为大家讲解word临时文件怎么恢复 word临时文件在哪个文件夹 如果你在编辑文件时 没有手
  • STL迭代器简介

    标准模板库 The Standard Template Library STL 定义了五种迭代器 下面的图表画出了这几种 input output forward bidirectional random access 要注意 上面这图表并
  • 实现简易版——MyLinkedList

    class Node String val Node pre 双向 Node next Node String val this val val public class MyLinkedList private Node head 头结点