现在的位置: 首页 > 综合 > 正文

java链表学习

2017年09月13日 ⁄ 综合 ⁄ 共 2174字 ⁄ 字号 评论关闭

首先设计一个节点类

class Node{
	private String name ;	// 保存节点的名字
	private Node next ;		// 保存下一个节点
	public Node(String name){
		this.name = name ;
	}
	public void setNext(Node next){
		this.next = next ;
	}
	public Node getNext(){
		return this.next ;
	}
	public String getName(){
		return this.name ;
	}
};

然后实现简单的链接

public class LinkDemo01{
	public static void main(String args[]){
		Node root = new Node("根节点") ;
		Node n1 = new Node("第一节车厢");
		Node n2 = new Node("第二节车厢");
		Node n3 = new Node("第三节车厢");

		root.setNext(n1) ;
		n1.setNext(n2) ;
		n2.setNext(n3) ;
		print(root) ;
	}
	public static void print(Node node){
		if(node!=null){
			System.out.print(node.getName() + " --> ") ;
		}
		if(node.getNext()!=null){
			print(node.getNext()) ;
		}
	}
};

实现一个简单的链表类:

class Link{
	class Node{
		private String name ;	// 保存节点的名字
		private Node next ;		// 保存下一个节点
		public Node(String name){
			this.name = name ;
		}
		public String getName(){
			return this.name ;
		}
		public void addNode(Node newNode){
			if(this.next==null){	// 后面没有东西
				this.next = newNode ;
			}else{
				this.next.addNode(newNode) ;	// 向下继续查
			}
		}
		public void printNode(){
			System.out.print(this.name + " --> " ) ;
			if(this.next!=null){
				this.next.printNode() ;	// 向下继续列出
			}
		}
		public boolean searchNode(String name){
			if(this.name.equals(name)){
				return true ;
			}else{
				if(this.next!=null){
					return this.next.searchNode(name) ;
				}else{
					return false ;
				}
			}
		}
		public void deleteNode(Node preNode,String name){
			if(this.name.equals(name)){
				preNode.next = this.next ;
			}else{
				this.next.deleteNode(this,name) ;
			}
		}
	};
	private Node root ;	// 要定义出根节点
	public void add(String name){
		Node newNode = new Node(name) ;
		if(this.root==null){	// 没有根节点,则把第一个作为根节点
			this.root = newNode ;
		}else{
			this.root.addNode(newNode) ;
		}
	}
	public void print(){
		if(this.root!=null){
			this.root.printNode() ;
		}
	}
	public boolean search(String name){	// 指定查找的名字
		if(this.root!=null){
			return this.root.searchNode(name) ;
		}else{
			return false ;
		}
	}
	public void delete(String name){
		if(this.search(name)){	// 判断此节点是否存在
			if(this.root.name.equals(name)){
				if(this.root.next!=null){
					this.root = this.root.next ;	// 改变根节点
				}else{
					this.root = null ;	// 取消
				}
			}else{
				if(this.root.next!=null){
					this.root.next.deleteNode(root,name) ;
				}
			}
		}
	}
};
public class LinkDemo02{
	public static void main(String args[]){
		Link link = new Link() ;
		link.add("根节点") ;
		link.add("第一节点") ;
		link.add("第二节点") ;
		link.add("第三节点") ;
		link.add("第四节点") ;
		link.add("第五节点") ;
		link.print() ;
		System.out.println() ;
		// System.out.println(link.search("第x节点")) ;
		link.delete("第四节点") ;
		link.delete("根节点") ;
		link.print() ;
	}
};

抱歉!评论已关闭.