链表

本文详细讲解了链表的基本概念,展示了如何在Java中通过伪代码和实例操作进行链表的插入(将22插入11和13之间)和删除(移除11和12间的13结点)。通过Node类设计,理解了链表的节点结构和操作方法。
摘要由CSDN通过智能技术生成

链表是一种物理存储单元上非连续、非顺序的存储结构,其物理结构不能直观地表示数据元素的逻辑顺序,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列的结点(链表中的每一个元素称为结点)组成,结点可以在运行时动态生成。

在这里插入图片描述
在这里插入图片描述
想要在11和13中插入22这个数据只需要将11的后继元素指向22将22的后继元素指向13从而就实现了往链表中插入数据的操作
用伪代码来描述:
设11这个结点为p,22这个结点为s,向11与13之中插入22可表示为:
p.next=s;//将11的后继元素指向22
s.next=p.next;//在原来的链表中13是11的后继元素 即13这个结点为p.next
在这里插入图片描述
想要删去11和12之间的结点13,只需要令11这个结点的后继元素不再指向13改为直接指向12
用伪代码来描述:
设11结点为p
p.next=p.next.next//让11的后继元素指向原来11的后继元素(13)的后继元素(12)。

知道了链表的一些属性,如何利用Java语言来使用链表?这就是研究的重点。
按照Java中面向对象的思想,我们可以设计一个类,来描述结点这个事物,用一个属性描述这个结点存储的元素,用另一个属性来描述这个结点存储的指针次序。

结点API设计:
在这里插入图片描述
结点类实现:

package com.jinglan.basics;

//结点类
public class Node<T> {
	public T item;// 存储元素
	public Node next;// 指向下一个结点
	// 构造方法

	public Node(T item, Node next) {
		this.item = item;
		this.next = next;
	}

	// 根据节点类生成链表
	public static void main(String[] args) {
		Node<Integer> first = new Node<Integer>(11, null);// 默认先不为当前结点设计指向下一个结点
		Node<Integer> second = new Node<Integer>(13, null);
		Node<Integer> third = new Node<Integer>(12, null);
		Node<Integer> fourth = new Node<Integer>(8, null);
		// 设计结点的指向
		first.next = second;// 让第一个结点指向第二个结点
		second.next = third;// 让第二个结点指向第三个结点
		third.next = fourth;// 让第三个结点指向第四个结点

	}
}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

立志Java工程师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值