zoukankan      html  css  js  c++  java
  • 单向链表的基本操作

    public class Link
    {
     public int data;
     public int key;
     public Link next;
     
     public void setdata(int data)
     {
      this.data=data;
     }
     
     public int getdata()
     {
      return this.data;
     }

     public void setkey(int key)
     {
      this.key=key;
     }
     public int getkey()
     {
      return this.key;
     }
     
     public void setnext(Link linknew)
     {
      this.next=linknew;
     }
     
     public Link getnext()
     {
      return this.next;
     }
    }

    ////////////////////////////

    public class LinkList
    {
     public static Link head;
     
     public LinkList()
     {
      head=null;
     }
     
     public  void createlink(int[] a)
     {
      Link Linknew;
      Link Linktail;
      Linktail=new Link();
      head=Linktail;
      for(int j=0;j<a.length;j++)
      {
       Linknew=new Link();
       Linknew.setdata(a[j]);
       Linknew.setkey(j);
       Linktail.setnext(Linknew);
       Linknew.setnext(null);
       Linktail=Linknew;
      }
      
     }
     
     public  void insertlink(int i,int data)
     {
      Link temp;
      temp=head.next;
      Link Linknew;
      while(temp!=null)
      {
       if(i-1==temp.getkey())
       {
        Linknew=new Link();
        Linknew.setdata(data);
        
        Linknew.setnext(temp.getnext());
        temp.setnext(Linknew);
        
        Linknew.setkey(i);
        Link a=Linknew;
        Link b=Linknew.next;
        while(b!=null)
        {
         b.setkey(i+1);
         i++;
         a=b;
         b=b.next;
        }
        System.out.println("insert success!");
        break;
       }
       else
       {
        temp=temp.next ;
       } 
      }
      if(temp==null)
      {
       System.out.println("insert failed!");
      }
     }
     
     public  void deletelink(int data)
     {
      Link temp=head.next;
      Link previoustemp=head;
      while(temp!=null)
      {
       if(data==temp.getdata())
       {
        int x;
        x=temp.getdata();
        previoustemp.setnext(temp.getnext());
        System.out.println("delete success!");
        break;
       }
       else
       {
        previoustemp=temp;
        temp=temp.getnext();
       }
      }
      if(temp==null)
      {
       System.out.println("no delete data ");
      }
      
     }
     
     public  void display()
     {
      Link p=head.next;
      while(p!=null)
      {
       System.out.print( p.getdata()+" ");
       p=p.getnext();
      }
      System.out.println( "");
     }

    }

    /////////////////////////////////////

    public class LinkListAPP
    {
     public static void main(String[] args)
     {
      int[] a=new int[10];
      for(int i=0;i<10;i++)
      {
       a[i]=i;
      }
      
      LinkList  thelist=new LinkList();
      thelist.createlink(a);
      thelist.display();
      
      thelist.insertlink(2,5);
      thelist.display();
      
      thelist.insertlink(3,0);
      thelist.display();
      
      thelist.insertlink(7,0);
      thelist.display();
      
      thelist.deletelink(9);
      thelist.display();
      
      
      thelist.deletelink(29);
      thelist.display();
      
     }
    }

    2./////////////////////////////////

    没有set和get方法的实现

    package datestructurelink;

    public class Node
    {
     public int key;
     public int data;
     public Node next;
     
     public Node()
     {
      key=0;
      data=0;
      next=null;
     }
     
     public Node(int ikey,int idata,Node next )
     {
      key=ikey;
      data=idata;
      next=null;
     }
    }

    ////////////////////////////

    package datestructurelink;

    public class NodeList
    {
     public Node head;
     
     public NodeList()
     {
      head=null;
     }
     
     public  void createlink(int[] a)
     {
      Node Linknew;
      Node Linktail;
      Linktail=new Node();
      head=Linktail;
      for(int j=0;j<a.length;j++)
      {
       Linknew=new Node();
       Linknew.data=a[j];
       Linknew.key=j;
       Linktail.next=Linknew;
       //Linknew.next=null;
       Linktail=Linknew;
      }
      
     }
     
     public  void insertlink(int i,int data)
     {
      Node temp;
      temp=head.next;
      Node Linknew;
      while(temp!=null)
      {
       if(i-1==temp.key)
       {
        Linknew=new Node();
        Linknew.data=data;
        
        Linknew.next=temp.next;
        temp.next=Linknew;
        
        Linknew.key=i;
        Node a=Linknew;
        Node b=Linknew.next;
        while(b!=null)
        {
         b.key=i+1;
         i++;
         a=b;
         b=b.next;
        }
        System.out.println("insert success!");
        break;
       }
       else
       {
        temp=temp.next ;
       } 
      }
      if(temp==null)
      {
       System.out.println("insert failed!");
      }
     }
     
     public  void deletelink(int data)
     {
      Node temp=head.next;
      Node previoustemp=head;
      while(temp!=null)
      {
       if(data==temp.data)
       {
        int x;
        x=temp.data;
        previoustemp.next=temp.next;
        System.out.println("delete success!");
        break;
       }
       else
       {
        previoustemp=temp;
        temp=temp.next;
       }
      }
      if(temp==null)
      {
       System.out.println("no delete data ");
      }
      
     }
     
     public  void display()
     {
      Node p=head.next;
      while(p!=null)
      {
       System.out.print( p.data+" ");
       p=p.next;
      }
      System.out.println( "");
     }

    }

    ///////////////////////////

    package datestructurelink;

    public class NodeListAPP
    {
     public static void main(String[] args)
     {
      int[] a=new int[10];
      for(int i=0;i<10;i++)
      {
       a[i]=i;
      }
      
      NodeList  thelist=new NodeList();
      thelist.createlink(a);
      thelist.display();
      
      thelist.insertlink(2,5);
      thelist.display();
      
      thelist.insertlink(3,0);
      thelist.display();
      
      thelist.insertlink(7,0);
      thelist.display();
      
      thelist.deletelink(9);
      thelist.display();
      
      
      thelist.deletelink(29);
      thelist.display();
      
     }
    }

  • 相关阅读:
    MTK 定时器 休眠时的动作
    Troubleshooting MySQL Memory Usage
    disruptor
    Google Protocol Buffer 的使用和原理
    百度贴吧10亿量级LAMP架构分享
    nginx 不带www到www域名的重定向
    配置电信网通双线双IP的解决办法
    Create a W3C validated anchor link with target=“_blank”
    Could not update ICEauthority file /home/username/.ICEauthority
    Can't load IA 32bit .dll on a AMD 64bit platform
  • 原文地址:https://www.cnblogs.com/growAriel/p/3613010.html
Copyright © 2011-2022 走看看