栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【数据结构】单向链表

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【数据结构】单向链表

Node.java 单向链表增加、删除

public class Node {
	Object data;
	Node next;
	
	
	public Node(Object data, Node next) {
		super();
		this.data = data;
		this.next = next;
	}
}

MylinkedList.java

public class MylinkedList {
	private Node head;//指向头结点的引用
	private int size;//结点数量
	
	
    public void add(Object data) {
    	Node newNode=new Node(data,null);//新节点	
    	if(size==0) {      //如果是空链表
    		head=newNode;  //新节点指向头节点
    	}else {           //不是空链表
    		Node tmp=head;    //tmp引用头节点 。保护头节点
    		while(tmp.next!=null) {
    			tmp=tmp.next;
    		}
    		tmp.next=newNode;
    	}
    	size++;
    }
    
    
    
    
    @Override
	public String toString() {
		Node tmp=head;
		StringBuilder sb=new StringBuilder();    	
		
		while(tmp!=null) { //循环遍历 记录结点上的值
			sb.append(tmp.data+",");
			tmp=tmp.next;
		}
    	return sb.toString();
	}



    
    public void remove(Object data) {
    	Node tmp=head;	
    	
    	   	
    	if(tmp.data.equals(data)) {
    		head=tmp.next;
    		tmp=null;	
    		return; //void return表示结束程序
		}
			
    	
    	while(tmp.next!=null){		
    	if(tmp.next.data.equals(data)) { //找到要删除结点的前一结点
    		Node font=tmp;           //待删除结点的前一结点
    		Node cur=tmp.next;       //待删除结点
    		Node back=tmp.next.next;//待删除结点的后一结点
    		font.next=back;
    		cur.next=null;	
    	}
    	tmp=tmp.next;
    }
    }
 
    
    public static void main(String[] args) {
		MylinkedList list=new MylinkedList();
		
		list.add(3);
		list.add(4);
		list.add(2);
		list.add(3);
		list.add(6);
		list.add(7);
		System.out.println(list);
		
		list.remove(3);//删头结点
		list.remove(3);//删中间结点
		System.out.println(list);
	}
}

结果

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/672984.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号