首页 > 其他分享 >2.链表

2.链表

时间:2022-11-14 22:23:55浏览次数:39  
标签:tmp name no HeroNode 链表 nickName public

1.链表介绍

  链表是有序的列表,但是他在内存中的存储如下:

小结:

  • 链表是以节点的方式存储
  • 每个节点包含data域和next域(指向下一个节点)
  • 如图:发现每个节点并不是一定连续的
  • 链表分带头节点的链表和没有头节点的链表,根据实际情况而定

  

    

场景:创建一个链表

  链表新增:

  

package cn.com.linkedList;

public class SingleLinkedListDemo {
    public static void main(String[] args) {
        SingleLinkedList singleLinkedList = new SingleLinkedList();
        HeroNode heroNode1 = new HeroNode(1, "宋江", "及时雨");
        HeroNode heroNode2 = new HeroNode(2, "卢俊义", "玉麒麟");
        HeroNode heroNode3 = new HeroNode(3, "吴用", "智多星");
        HeroNode heroNode4 = new HeroNode(4, "林冲", "豹子头");
        singleLinkedList.add(heroNode1);
        singleLinkedList.add(heroNode2);
        singleLinkedList.add(heroNode3);
        singleLinkedList.add(heroNode4);
        singleLinkedList.list();
    }
}

//管理英雄
class SingleLinkedList {
    //1.定义一个头元素,只是表明头元素
    HeroNode head = new HeroNode(0, "", "");

    /**
     * 添加
     *
     * @param node
     */
    public void add(HeroNode node) {
        //定义一个临时变量,因为head不能变化,所以定义一个中间变量
        HeroNode tmp = head;
        //找到队列的最后一个元素,最后一个元素的next=null
        while (tmp.getNext() != null) {
            tmp = tmp.getNext();
        }
        tmp.setNext(node);
    }

    /**
     * 遍历输出
     */
    public void list() {
        if (head.getNext() == null) {
            System.out.println("链表为空!");
            return;
        }
        HeroNode tmp = head.getNext();
        //找到队列的最后一个元素,最后一个元素的next=null
        while (true) {
            if (tmp == null) {
                break;
            }
            System.out.println(tmp.toString());
            tmp = tmp.getNext();
        }
    }
}

class HeroNode {
    //英雄编号
    private int no;
    //英雄名称
    private String name;
    //艺名
    private String nickName;
    //下一个
    private HeroNode next;

    public HeroNode(int no, String name, String nickName) {
        this.no = no;
        this.name = name;
        this.nickName = nickName;
    }

    public int getNo() {
        return no;
    }

    public void setNo(int no) {
        this.no = no;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getNickName() {
        return nickName;
    }

    public void setNickName(String nickName) {
        this.nickName = nickName;
    }

    public HeroNode getNext() {
        return next;
    }

    public void setNext(HeroNode next) {
        this.next = next;
    }

    @Override
    public String toString() {
        return "HeroNode{" +
                "no=" + no +
                ", name='" + name + '\'' +
                ", nickName='" + nickName + '\'' +
                '}';
    }
}

 

package cn.com.linkedList;

public class SingleLinkedListDemo {
    public static void main(String[] args) {
        SingleLinkedList singleLinkedList = new SingleLinkedList();
        HeroNode heroNode1 = new HeroNode(1, "宋江", "及时雨");
        HeroNode heroNode2 = new HeroNode(2, "卢俊义", "玉麒麟");
        HeroNode heroNode3 = new HeroNode(3, "吴用", "智多星");
        HeroNode heroNode4 = new HeroNode(4, "林冲", "豹子头");
        singleLinkedList.add(heroNode1);
        singleLinkedList.add(heroNode2);
        singleLinkedList.add(heroNode3);
        singleLinkedList.add(heroNode4);
        singleLinkedList.list();
    }
}

//管理英雄
class SingleLinkedList {
    //1.定义一个头元素,只是表明头元素
    HeroNode head = new HeroNode(0, "", "");

    /**
     * 添加
     *
     * @param node
     */
    public void add(HeroNode node) {
        //定义一个临时变量,因为head不能变化,所以定义一个中间变量
        HeroNode tmp = head;
        //找到队列的最后一个元素,最后一个元素的next=null
        while (tmp.getNext() != null) {
            tmp = tmp.getNext();
        }
        tmp.setNext(node);
    }

    /**
     * 遍历输出
     */
    public void list() {
        if (head.getNext() == null) {
            System.out.println("链表为空!");
            return;
        }
        //head一定不为空,tmpp就是第一个有效数据
        HeroNode tmp = head.getNext();
        //找到队列的最后一个元素,最后一个元素的next=null
        while (true) {
            if (tmp == null) {
                break;
            }
            System.out.println(tmp.toString());
            tmp = tmp.getNext();
        }
        
        上述判断也可以这么写:
        HeroNode tmp = head;
        //找到队列的最后一个元素,最后一个元素的next=null
        while ((tmp=tmp.getNext())!=null) {
            System.out.println(tmp.toString());
        }
    }
}

class HeroNode {
    //英雄编号
    private int no;
    //英雄名称
    private String name;
    //艺名
    private String nickName;
    //下一个
    private HeroNode next;

    public HeroNode(int no, String name, String nickName) {
        this.no = no;
        this.name = name;
        this.nickName = nickName;
    }

    public int getNo() {
        return no;
    }

    public void setNo(int no) {
        this.no = no;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getNickName() {
        return nickName;
    }

    public void setNickName(String nickName) {
        this.nickName = nickName;
    }

    public HeroNode getNext() {
        return next;
    }

    public void setNext(HeroNode next) {
        this.next = next;
    }

    @Override
    public String toString() {
        return "HeroNode{" +
                "no=" + no +
                ", name='" + name + '\'' +
                ", nickName='" + nickName + '\'' +
                '}';
    }
}

输出:

HeroNode{no=1, name='宋江', nickName='及时雨'}
HeroNode{no=2, name='卢俊义', nickName='玉麒麟'}
HeroNode{no=3, name='吴用', nickName='智多星'}
HeroNode{no=4, name='林冲', nickName='豹子头'}

 

标签:tmp,name,no,HeroNode,链表,nickName,public
From: https://www.cnblogs.com/wmd-l/p/16890699.html

相关文章

  • 【数据结构/C语言】借助于栈将一个带头结点的单链表L逆置
    编写算法Reverse(LinkList&L),要求借助于栈将一个带头结点的单链表L逆置。其中栈的初始化操作、入栈操作和出栈操作算法名分别为InitStack(&S)、Push(&S,e)、Pop(&S,&e),单......
  • 力扣24 两两交换链表中的节点
    题目:给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。示例:输入:head=[1,2,3,4]......
  • 彻底搞懂React-hook链表构建原理
    写在前面的小结每一个hook函数都有对应的hook对象保存状态信息useContext是唯一一个不需要添加到hook链表的hook函数只有useEffect、useLayoutEffect以及us......
  • 计算机等级考试二级C语言程序设计专项训练题——单链表
    一.程序填空题1.给定程序的主函数中,已给出由结构体构成的链表结点a、b、c,各结点的数据域中均存入字符,函数fun的功能是:将a、b、c三个结点链接成一个单向链表,并输出链表结点中......
  • 队列链表实现
    队列没有元素是FrontRear指向NULL 只有一个元素时都指向那一个元素因为既是第一个元素也是最后一个元素即队头队尾 Front指向第一个元素Rear指向最后一个元素#......
  • #yyds干货盘点# LeetCode 腾讯精选练习 50 题:相交链表
    题目:给你两个单链表的头节点 headA和headB,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回null。图示两个链表在节点c1开始相交:题目数据......
  • 力扣206 反转链表
    题目:给你单链表的头节点head,请你反转链表,并返回反转后的链表。示例:输入:head=[1,2,3,4,5]输出:[5,4,3,2,1] 双指针法:两个指针,cur指向当前节点,用来遍历,pre......
  • 21. 合并两个有序链表 ----- 递归调用、链表指针
    将两个升序链表合并为一个新的升序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。  示例1:输入:l1=[1,2,4],l2=[1,3,4]输出:[1,1,2,3,4,4]示例......
  • 单链表的算法
    单链表的算法先进先出单链表(尾插法)首先我们要知道什么是先进先出:每次插入的新元素,都是插在表尾。就比如饭堂打饭排队的时候,第一个打饭的人往往是第一个离开的,以此类推,最......
  • HTML-链表标签和块标签
    链表标签a:定义一个超链接属性:href:指定访问资源的URL(统一资源定位符)target:指定打开资源的方式_self:默认值,在当前页面打开_blank:在空白页面打开......