zoukankan      html  css  js  c++  java
  • 用Java实现单链表的基本操作

      笔试题中经常遇到单链表的考题,下面用java总结一下单链表的基本操作,包括添加删除节点,以及链表转置。

    package mars;
    
    //单链表添加,删除节点
    public class ListNode {
        
        private Node head;
        
        public ListNode(){
            head=null;
        }
        //在链表前添加节点
        public void addpre(int dvalue){
            Node n=new Node(dvalue);
            
            if(head==null){
                head=n;
            }else{
                n.next=head;
                head=n;
            }
            
        }
        //在链表后添加节点
        public void add(int dvalue){
            Node n=new Node(dvalue);
            Node current = head;  
            while(current!=null){
                if(current.next==null){
                    current.next=n;
                    return;
                }
                current=current.next;
            }
            
        }
        //删除值为dvalue的节点
        public Node delete(int dvalue){
            Node current=head;
            if(head.value==dvalue){
                head=head.next;
                return current;
            }
            while(current.next!=null){
                if(current.next.value==dvalue){
                    Node temp=current.next;
                    current.next=temp.next;
                    return temp;
                }
                current=current.next;
            }
            return null;
        }
        //删除特定位置的节点
        public Node deletepos(int pos){
            Node current=head;
            int counter=0;
            if(pos==0){
                head=head.next;
                return current;
            }
            while(current!=null){
                if((counter==(pos-1))&&(current.next!=null)){
                    Node temp=current.next;
                    current.next=temp.next;
                    return temp;
                }
                current=current.next;
                counter++;
            }
    
            return null;
            
        }
        //单链表转置
        public void reverse(){
            Node a=head;
            if(a==null){
                return ;
            }
            Node b=head.next;
            if(b==null){
                return ;
            }
            Node c=head.next.next;
            a.next=null;
            while(c!=null){
                b.next=a;
                a=b;
                b=c;
                c=c.next;
            }
            b.next=a;
            head=b;
        }
        //输出链表信息
        public void print(){
            Node current = head;  
            while(current!=null){
                System.out.println(current.value);
                current=current.next;
            }
            
        }
        
        public static void main(String[] args){
     
            ListNode l=new ListNode();
            l.addpre(3);
            l.addpre(2);
            l.addpre(1);
            l.add(7);
            l.add(8);
            l.add(9);
            l.delete(1);
            l.deletepos(4);
            l.reverse();
            l.print();
        }
        
    }
    
    class Node{
        public Node next;
        public int value;
        public Node(){
            next=null;
        }
        public Node(int v){
            value=v;
        }
    }

    PS:Java的引用类似于C的指针,例如 :

         Node n1=new Node(1);    Node n2=n1;    Node n3=new Node(3);   n2=n3;

    执行n2=n1后,n1和n2都是对同一块内存区域(区域1)的引用,通过n1和n2都可以达到修改内存区域1的目的,例如执行n1.value=10后,输出n2.value的值也为10。但是执行n2=n3后,n2则变为了对另一块内存区域(区域3)的应用。

  • 相关阅读:
    mybatis 使用缓存策略
    mybatis 使用事务处理
    mybatis 使用接口绑定
    mybatis 配置文件全解
    mybatis mapper映射文件全解
    mybatis中使用log4j
    初次使用Mybatis
    Servlet 实现文件上传与下载
    log4j v2版本的配置和使用
    Servlet 转发请求与重定向,以及路径问题
  • 原文地址:https://www.cnblogs.com/z-belief/p/5610468.html
Copyright © 2011-2022 走看看