java--实现单链表

 

class Link{
 class Node{
 private String data;
 private Node next;
 public Node(String data){
  this.data=data;
 }
 public void add(Node newNode){
  if(this.next==null){
   this.next=newNode;
  }
  else{
   this.next.add(newNode);
  }
 }
 public void print(){
  System.out.print(this.data+"\t");
  if(this.next!=null){
   this.next.print();
  }
 }
 public boolean search(String data){
  if(data.equals(this.data)){
   return true;
  }
  else{
   if(this.next!=null){
    return this.next.search(data);
   }
   else{
    return false;
  
   }
  }
 }
 public void delete(Node previous,String data){
  if(data.equals(this.data)){
   previous.next=this.next;
   
  }
  else{
   if(this.next!=null){
    this.next.delete(this, data);
   }
  }
 }
 }
 private Node root;
 public void addNode(String data){
  Node newNode=new Node(data);
  if(this.root==null){
   this.root=newNode;
   
  }
  else{
   this.root.add(newNode);
  }
 }
 public void printNode(){
  if(this.root!=null){
   this.root.print();
  }
  
 }
 public boolean contains(String name){
  return this.root.search(name);
 }
 public void deleteNode(String data){
  if(this.contains(data)){
   if(this.root.data.equals(data)){
    this.root=this.root.next;
    
   }
   else{
    this.root.next.delete(root, data);
   }
  }
 }
}

 


public class LinkDemo02 {
 public static void main(String args[]){
  Link l=new Link();
  l.addNode("A");
  l.addNode("B");
  l.addNode("C");
  l.addNode("D");
  l.addNode("E");
  System.out.println("==========删除之前=============");
  l.printNode();
  l.deleteNode("C");
  l.deleteNode("D");
  System.out.println();
  System.out.println("===========删除之后============");
  l.printNode();
  System.out.println();
  System.out.println("查询节点"+l.contains("A"));
 }

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值