链表(Linked List)介绍
链表是有序的列表,但是它在内存中是存储如下
小结:
1、链表是以节点的方式来存储,是链式存储。
2、每个节点包含 data 域, next 域:指向下一个节点。
3、如图:发现链表的各个节点不一定是连续存储。
4、链表分带头节点的链表和没有头节点的链表,根据实际的需求来确定。
单链表介绍
单链表(带头结点) 逻辑结构示意图如下
单链表的应用实例
使用带head头的单向链表实现 –水浒英雄排行榜管理 完成对英雄人物的增删改查操作 第一种方法在添加英雄时,直接添加到链表的尾部 第二种方式在添加英雄时,根据排名将英雄插入到指定位置(如果有这个排名,则添加失败,并给出提示)
代码
package com.lin.linkedlist_0131; /** * 在内存里面直接将数据排好,不用在数据库里面排,效率高 * @Description: * @author LinZM * @date 2021-1-31 20:40:54 * @version V1.8 */ public class SingleLinkedListTest { public static void main(String[] args) { SingleLinkedList singleLinkedList = new SingleLinkedList(); // singleLinkedList.addHero(new HeroNode(1, "伍六七", "柒")); // singleLinkedList.addHero(new HeroNode(2, "赵六", "陆")); // singleLinkedList.addHero(new HeroNode(3, "一二三", "叁")); // singleLinkedList.addHero(new HeroNode(4, "李爸爸", "捌")); // singleLinkedList.addHero(new HeroNode(5, "李妈妈", "玛")); singleLinkedList.addHeroByOrder(new HeroNode(1, "伍六七", "柒")); singleLinkedList.addHeroByOrder(new HeroNode(2, "赵六", "陆")); singleLinkedList.addHeroByOrder(new HeroNode(2, "赵六", "陆")); singleLinkedList.addHeroByOrder(new HeroNode(4, "李爸爸", "捌")); singleLinkedList.addHeroByOrder(new HeroNode(3, "一二三", "叁")); singleLinkedList.list(); } } /** * * @Description: 定义SingleLinkedList管理英雄 * @author LinZM * @date 2021-1-31 20:46:53 * @version V1.8 */ class SingleLinkedList{ // 初始化头结点,一般不动 private HeroNode head = new HeroNode(0, "", ""); /** * 添加节点到单向链表 * 1 找到当前链表的最后节点 * 2 将最后这个节点的next指向新的节点 * @Description: * @author LinZM * @date 2021-1-31 21:12:23 * @version V1.8 */ public void addHero(HeroNode heroNode){ // 因为head节点不能动,因此我们需要一个辅助变量temp HeroNode temp = head; // 遍历链表,找到最后节点 while(true) { if(temp.next == null) { break; } // 如果没有找到,就将这个temp后移 temp = temp.next; } // 当循环结束时,temp指向链表最后 // 将最后这个节点的next指向新的节点 temp.next = heroNode; } // 第二种方式添加英雄是,根据排名将英雄插入到指定位置 // (如果相同排名则插入失败) public void addHeroByOrder(HeroNode heroNode) { HeroNode temp = head; boolean flag = false;// 标识添加的编号是否存在 while(true) { if(temp.next == null) { break; } if(temp.next.no > heroNode.no) { break; }else if(temp.next.no == heroNode.no) { flag = true; break; } temp = temp.next; } // 退出循环后 // 判断flag if(flag) { System.out.printf("待插入的英雄的编号%d已经存在,不能添加了\n",heroNode.no); } else { // 尾插法 // 新节点.next = temp.next // temp.next = 新节点 heroNode.next = temp.next; temp.next = heroNode; } } // 显示链表 public void list() { // 判断链表是否为空 if(head.next == null) { System.out.println("链表为空!"); return; } // 因为头结点不动,因此我们需要一个辅助变量temp HeroNode temp = head.next; while(true) { // 判断是否到链表最后 if(temp == null) { break; } // 输出链表信息 System.out.println(temp); temp = temp.next; } } } /** * * @Description: 定义HeroNode,每个HeroNode对象时一个节点 * @author LinZM * @date 2021-1-31 20:47:02 * @version V1.8 */ class HeroNode{ public int no; public String name; public String nickname; public HeroNode next; public HeroNode(int no, String name, String nickname) { super(); this.no = no; this.name = name; this.nickname = nickname; } @Override public String toString() { return "HeroNode [no=" + no + ", name=" + name + ", nickname=" + nickname + "]"; } }
仅供参考,有错误还请指出!
有什么想法,评论区留言,互相指教指教。
原文:https://www.cnblogs.com/linzm14/p/14354183.html