会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132600个问题

package com.xazynl;

/**
 * projectName: NQZ
 *
 * @author: 谢新建
 * time: 2021/4/4 16:07
 * description:
 * 基于单向链表存取的容器
 */
public class MySinglyLinkedList <E > implements MyList<E>{
    //定义单向链表中的节点类对象
    class Node<E>{
        private E item;     //储存元素
        private Node next;  //存储下一个节点对象的地址
        Node(E item,Node next){
            this.item=item;
            this.next=next;
        }
    }

    private Node head;//存放链表中的头节点。
    private  int size;//记录元素个数。
    //向链表中添加元素
    @Override
    public void add(E element) {
        //创建节点
        Node<E> node = new Node<>(element,null);
        //找到尾节点
        Node tail=getTail();
        //节点的挂接
        if (tail==null)
            this.head=node;
        else
            tail.next=node;
        //记录元素个数
        this.size++;

    }
    //找到尾节点
    private Node getTail(){
        //头节点是否存在
        if (this.head==null){
            return null;
        }
        //查找尾节点
        Node node=this.head;
        while (true){
            if (node.next==null)break;
            node=node.next;//移动指针,指向下一个节点
        }
        return node;
    }
    //根据元素的位置获取元素
    @Override
    public E get(int index) {
        //校验index的合法性
        this.checkIndex(index);
        //根据位置获取指定节点
        Node<E> node = this.getNode(index);
        //将该节点中的元素返回
        return node.item;
    }
    //对index进行校验
    private void checkIndex(int index){
        if (!(index>=0 && index < this.size)){
            throw new IndexOutOfBoundsException("Index"+index+""+this.size);
        }
    }
    //根据位置获取节点
    private Node getNode(int index){
        Node<E> node = this.head;
        for (int i=0;i<index;i++){
            node=this.head;
        }
        return node;
    }
    //获取元素个数
    @Override
    public int size() {
        return this.size;
    }
    //根据元素的位置删除元素
    @Override
    public E remove(int index) {
        //校验index的合法性
        this.checkIndex(index);
        //根据位置找到该节点对象
            Node<E> node=this.getNode(index);
        //获取该节点中对象的元素
        E item =node.item;
        //将该节点对象从单向链表中移除
          //判断当前删除节点是否为头节点
        if (this.head==node){
            this.head=node.next;
        }else {
            Node<E> temp=this.head;
            for (int i=0;i < index - 1;i++){
                temp=temp.next;
            }
            temp.next=node.next;
        }
            node.next=null;
        //记录元素个数
        this.size--;
        //将元素返回
        return item;
    }

    public static void main(String[] args) {
        MySinglyLinkedList<String> mySinglyLinkedList=new MySinglyLinkedList<>();
        mySinglyLinkedList.add("a");
        mySinglyLinkedList.add("b");
        mySinglyLinkedList.add("c");
        mySinglyLinkedList.add("d");
        mySinglyLinkedList.add("e");
        System.out.println(mySinglyLinkedList.size());
        System.out.println("----------------");
        System.out.println(mySinglyLinkedList.remove(0));
        System.out.println("-------------------");
        for (int i=0;i< mySinglyLinkedList.size();i++){
            System.out.println(mySinglyLinkedList.get(i));
        }
    }
}

image.png

image.png问题:取值的时候为什么会只取b,我也用老师的源码运行了也是一样的

JAVA 全系列/第二阶段:JAVA 基础深化和提高/数据结构 27016楼
WEB前端全系列/第一阶段:HTML5+CSS3模块/CSS常用属性 27017楼
JAVA 全系列/第十八阶段:亿级高并发电商项目/亿级高并发电商项目(旧) 27021楼
JAVA 全系列/第十三阶段:高性能数据处理、NoSQL、分库分表/MyCat 27022楼
JAVA 全系列/第二十一阶段:分布式医疗云平台/收费管理前后端开发(旧) 27023楼
Python 全系列/第十五阶段:Python 爬虫开发/爬虫反反爬 27024楼
WEB前端全系列/第一阶段:HTML5+CSS3模块/商城官网项目 27025楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 27026楼
JAVA 全系列/第十三阶段:分布式文件存储与数据缓存/Redis 27027楼
JAVA 全系列/第十二阶段:Spring Cloud Alibaba技术栈/Zookeeper 27028楼

1. 源码.zip

老师,为什么我的adminData的数据接受有不到呢,但是我看adminData数据是存在的,同级的vipData数据都可以正常引入。


WEB前端全系列/第十九阶段:Vue3企业级项目/Vue3企业级项目 27030楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637