java中单链表和双向链表的实现

目录

单链表

创建一个对象,并设置节点

链表的增删改

输入数据测试

重写tostring

双链表

创建一个双链表

双向链表的增删改

重写tostring


单链表

链表都是通过节点来相互连接的,由于在java中没有指针的,所以java中是通过对象调对象来实现的

创建一个对象,并设置节点

class Node {
	Object date;
	Node next;
	public Node(Object date) {
		super();
		this.date = date;
	}
	@Override
	public String toString() {
		return "Node [date=" + date + "]";
	}
	
}

链表的增删改

增加

public  Node head=new Node(null);//设置头结点
	
	public void add(Node node){
		Node temp=head; //让第一个节点为头结点
		while(true){
			if(temp.next==null){//如果循环之后节点的下一个节点为空,那么就是尾结点
				break;
			}
			temp=temp.next;//指向下一个节点
		}
		temp.next=node;//把尾结点赋值
	}

删除

public void delete(Object obj){
		Node temp=head;
		boolean flag=false;
		while(true){
			if(temp.next==null){
				break;
			}
			if(temp.next.date.equals(obj)){
				flag=true;
				break;
			}
			temp=temp.next;
		}
		if(flag){
			temp.next=temp.next.next;
		}else{
			System.out.println("要删除的节点不存在"+obj);
		}
	}

修改和添加类似,就是循环的时候节点的属性值等于输入的属性值就查到了这个节点并修改节点的数据

输入数据测试

public class SingleLinkedListTest{
	public static void main(String[] args) {
		singleLinkedList list=new singleLinkedList();
		list.add(new Node("zs"));
		list.add(new Node("zs2"));
		list.list();
		list.delete("zs");
		list.list();
	}
}

重写tostring

@Override
	public String toString(){
		StringBuilder sb=new StringBuilder();
		Node temp=first;
		sb.append("[");
		while (temp.getNext()!=null) {
			sb.append(temp.toString());
			temp=temp.getNext();
		}
		sb.append("]");
		return sb.toString();
	} 

双链表

双链表和单例表不同的是,双链表要设置一个前驱节点,也就是这个前驱节点要指向前一个节点,所以在增删改的时候不用再通过节点的下一个节点来指向了

创建一个双链表

package com.DoubleLinkedList;

public class Node {
	private Object date;
	private Node next;
	private Node prv;
	
	public Node(Object date, Node next, Node prv) {
		super();
		this.date = date;
		this.next = next;
		this.prv = prv;
	}
	public Object getDate() {
		return date;
	}
	public void setDate(Object date) {
		this.date = date;
	}
	public Node getNext() {
		return next;
	}
	public void setNext(Node next) {
		this.next = next;
	}
	public Node getPrv() {
		return prv;
	}
	public void setPrv(Node prv) {
		this.prv = prv;
	}
	@Override
	public String toString() {
		return "{date=" + date + "}";
	}
	
}

双向链表的增删改

增加

  public void add(Object obj){
	    	Node newnod=new Node(obj,null,null);//同样的定义头结点
	    	if(first==null){
	    		first=newnod;//第一个节点就是头结点
	    	}else {
				Node temp=first;
				while (temp.getNext()!=null) {//循环找到尾结点
					temp=temp.getNext();//当前节点指向下一个节点
				}
//				形成一个双向链表
				temp.setNext(newnod);//添加数据,尾结点就是输入的数据
				newnod.setPrv(temp);//同时设置添加数据的前置节点就是前一个节点
			}
	    	size++;//记录链表长度的
	    }

删除

  public void delete(Object obj){
	    	Node newnod=new Node(obj,null,null);
	    	boolean flag=false;
	    	if(first==null){
	    		first=newnod;
	    	}else{
	    		Node temp=first.getNext();
//	    		因为是双链表所以直接找到该节点就行,不用通过下一个节点来删除
	    		while(true){
	    			if(temp==null){
	    				break;
	    			}
	    			if(temp.getDate().equals(obj)){
	    				flag=true;
	    				break;
	    			}
//	    			循环到下一个节点
	    			temp=temp.getNext();
	    		}
	    		if(flag){
	    			/*temp.setNext(temp.getNext().getNext());*/
	    			temp.getPrv().setNext(temp.getNext());
	    			size--;
	    		}else{
	    			System.out.println("要删除的节点不存在"+obj);
	    		}
	    	}
	    }

修改同上

重写tostring

	@Override
		public String toString(){
			StringBuilder sb=new StringBuilder();
			Node temp=first;
			sb.append("[");
			while (temp.getNext()!=null) {//相当于就是循环链表,然后打印每个节点的数据而已
				sb.append(temp.toString());
				temp=temp.getNext();
			}
			sb.append("]");
			return sb.toString();
		}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java单向链表是一种常见的数据结构,它由一系列节点组成,每个节点包含数据和指向下一个节点的指针。单向链表的特点是只能从头节点开始遍历到尾节点,不能反向遍历。 下面是一个简单的Java实现单向链表的例子: ```java public class Node { int data; // 节点数据 Node next; // 指向下一个节点的指针 public Node(int data) { this.data = data; this.next = null; } } public class LinkedList { Node head; // 链表头节点 public LinkedList() { this.head = null; } // 在链表尾部添加节点 public void add(int data) { Node newNode = new Node(data); if (head == null) { head = newNode; } else { Node current = head; while (current.next != null) { current = current.next; } current.next = newNode; } } // 在链表查找某个节点是否存在 public boolean contains(int data) { Node current = head; while (current != null) { if (current.data == data) { return true; } current = current.next; } return false; } // 删除链表第一个出现的指定节点 public void remove(int data) { if (head == null) { return; } if (head.data == data) { head = head.next; return; } Node current = head; while (current.next != null) { if (current.next.data == data) { current.next = current.next.next; return; } current = current.next; } } // 获取链表的节点数 public int size() { int count = 0; Node current = head; while (current != null) { count++; current = current.next; } return count; } } ``` 在上面的代码,Node类表示链表节点,LinkedList类表示单向链表。它包含了添加、查找、删除和获取节点数等常见操作。你可以根据自己的实际需求来对链表进行操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值