一、链表是有序的列表,它在内存中的存储如下:
链表是以节点的方式存储的,是链式存储每个节点包含data域(存数据),next域(指向下一个节点)链表的各个节点不一定是连续存储的链表分带头节点的链表和不带头节点的链表,根据实际的需求来确定
二、单链表的添加:
添加:
1.先创建一个头节点,用于表示单链表的头
2.后面我们每添加一个节点,就直接加入到链表的最后
遍历:
1.通过一个辅助变量,帮助遍历整个单链表
三、代码实现
//定义HeroNode,每个HeroNode对象就是一个节点
class HeroNode{
public int no;
public String name;
public String nickname;
public Heronode next; //指向下一个节点
//构造器
public Heronode(int no, String name, String nickname) {
this.no = no;
this.name = name;
this.nickname = nickname;
}
//为了显示方便,我们重写一下toString方法
@Override
public String toString() {
return "HeroNode{" +
"no=" + no +
", name='" + name + ''' +
", nickname='" + nickname + ''' +
'}';
}
}
//定义一个SinglelinkedList来管理我们的Hero
class SinglelinkedList{
//先初始化一个头节点,头节点不要动,不存储任何的数据
Heronode head = new Heronode(0,"","");
//添加节点到我们的单向链表
//思路:当不考虑顺序时
//1.先找到链表的最后一个节点
//2.将最后这个节点的next指向新的节点
public void addNode(Heronode heroNode){
//因为head节点不能动,我们需要一个辅助变量temp
Heronode temp = head;
//遍历链表,找到最后
while(true){
//找到最后一个节点
if(temp.next == null){
break;
}
//如果没有找到,则将temp后移
temp = temp.next;
}
//当退出循环的时候,temp指向了链表最后的节点
temp.next = heroNode;
}
//显示链表:通过一个辅助变量,帮助遍历整个单链表
public void showList(){
//判断链表是否为空
if(head.next == null){
System.out.println("链表为空!");
return;
}
//因为头节点不能动,因此我们需要一个辅助变量来遍历
Heronode temp = head.next;
while(true){
//判断什么时候遍历完链表
if(temp == null){
break;
}
System.out.println(temp);
temp = temp.next;
}
}
}
测试:
public static void main(String[] args){
//创建节点
Heronode hero1 = new Heronode(1, "宋江", "及时雨");
Heronode hero2 = new Heronode(2, "卢俊义", "玉麒麟");
Heronode hero3 = new Heronode(3, "无用", "智多星");
Heronode hero4 = new Heronode(4, "林冲", "豹子头");
//创建链表
SinglelinkedList list = new SinglelinkedList();
//加入节点
list.addNode(hero1);
list.addNode(hero4);
list.addNode(hero2);
list.addNode(hero3);
//显示链表
list.showList();
}
结果展示:



