Java数据结构——双向链表

双向链表:

每个节点中除了保存了指向后一个节点的指针外,还保存了指向前一个节点的指针


实现思路:

相关方法实现与单链表类似,不同点在于需要增加对指向前一个节点的指针的更改


代码实现:

节点类DoubleNode:

public class DoubleNode {
	public int data;
	public DoubleNode next;
	public DoubleNode pre;

	public DoubleNode(int data) {
		this.data = data;
	}

	@Override
	public String toString() {
		return "DoubleNode{" + "data=" + data + '}';
	}
}

双向链表类DoubleLinkedList:

public class DoubleLinkedList {
	public DoubleNode head = new DoubleNode(0);

	//获取头结点
	public DoubleNode getHead() {
		return head;
	}

	//添加节点
	public void add(DoubleNode doubleNode) {
		DoubleNode temp = head;
		//找到链表最后一个节点
		while (temp.next != null) {
			temp = temp.next;
		}
		temp.next = doubleNode;
		doubleNode.pre = temp;
	}

	//删除节点
	public void delete(int data) {
		DoubleNode temp = head.next;
		boolean flag = false;    //标志是否找到待删除节点的前一个节点
		while (true) {
			if (temp == null) {
				//已经遍历到链表最后了
				break;
			} else if (temp.data == data) {
				//找到待删除节点
				flag = true;
				break;
			}
			temp = temp.next;
		}
		if (flag) {
			temp.pre.next = temp.next;
			if (temp.next != null) {
				//若删除节点不为最后一个节点
				temp.next.pre = temp.pre;
			}
		} else {
			System.out.println("要删除的节点不存在");
		}
	}

	//输出链表
	public void show() {
		//判断链表是否为空
		if (head.next == null) {
			System.out.println("链表为空");
			return;
		}
		DoubleNode temp = head.next;
		while (temp != null) {
			System.out.println(temp);
			temp = temp.next;
		}
	}
}

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值