数据结构——单链表
相信看这篇的同学大多都是刚上大一的萌萌萌萌新,不巧的是,我当年比你们还要萌一点,所以还是要以书上的为基准。
引言:
神说:要有光,于是便有了光。
某位计算机科学家说:要有储存结构,于是便有了数组和链表。
链表,链表,顾名思义就是链式存储结构,想一想你们平时骑得共享单车的车链子就知道它大概是个什么亚子了。
链表的介绍:
(from 百度百科)
太懒了就不打了,直接传送门吧。
链表的创建、添加、查找、删除:
先说一下链表的大致样子吧。
这里用单链表来举例:
(盗个图)
上面的图就是一个单链表。它里面有四个结点。又要讲一下结点,结点是链表存储数据的最基础的结构,每个结点分为两块:数据域和指针域。数据域就是用来存储数据的,指针域就是用来存储下一个结点的位置的。再多一句嘴,指针这个东西是C和C++里面最重要的东西,首先指针这个名字就是他的作用,指向一个东西。但其实指针里面存放的是变量在内存中的地址,所以在链表节点中,它就像一个链子一样,把该节点和下一个结点绑住。
节点类定义:
//链表节点类
public class Node{
public Object data;
public Node next;
Node(){
}
Node(Object data){ this.data=data; }
}
链表定义:
public class SingleLinkedList {
private int size; //链表节点的个数
private Node head;
public SingleLinkedList(){
size = 0;
head = null;
}
//在链表头部添加元素
public Object addHead(Object obj){
Node newhead = new Node(obj);
if(size == 0){
head = newhead;
}else{
newhead.next = head;
head = newhead;
}
size++;
return obj;
}
//在单链表头部进行删除
public Object delHead(){
Object obj = head.data;
head = head.next;
size--;
return obj;
}
//查找返回指定节点,找不到,返回Null
public Node FindNode(Object obj){
Node currnet = head;
for(int i = 0; i < size; i++){
if(obj.equals(currnet.data)){
return currnet;
}else{
currnet = currnet.next;
}
}
return null;
}
//删除指定元素,成功返回ture
public boolean delete(Object obj){
if(size == 0){
return false;
}
Node current = head;
Node previous = head;
while(!current.data.equals(obj)){
if(current.next == null){
return false;
}else{
previous = current;
current = current.next;
}
}
//如果删除的节点是第一个节点
if(current == head){
head = current.next;
size--;
}else{
//删除的节点不是第一个节点
previous.next = current.next;
size--;
}
return true;
}
//判断链表是否为空
public boolean isEmpty(){
return (size == 0);
}
//显示节点信息
public void display(){
if(size > 0){
Node node = head;
int template = size;
if(template == 1){
System.out.println("[" + node.data + "]");
return;
}
while(template > 0){
if(node.equals(head)){
System.out.print("["+node.data + "->");
}else if(node.next == null){
System.out.print(node.data + "]");
}else{
System.out.print(node.data + "]");
}
node = node.next;
template--;
}
System.out.println();
}else{
System.out.println("没有节点");
}
}
}