1. //双向链表类
  2. publicclassDoubleLinkList{
  3.  
  4.     //结点类
  5.     publicclassNode{
  6.  
  7.         publicObject data;
  8.         publicNode next;
  9.         publicNode prior;
  10.  
  11.         publicNode(Object obj,Node next,Node prior){
  12.             this.data = obj;
  13.             this.next = next;
  14.             this.prior = prior;
  15.         }
  16.     }
  17.  
  18.     Node head;          //记录头结点信息即可(头结点下标为-1)
  19.     int size;
  20.  
  21.     //初始化一个空链表
  22.     publicDoubleLinkList(){
  23.         //初始化头结点,让头指针指向头结点。并且让当前结点对象等于头结点。
  24.         this.head =newNode(null, null, null);
  25.         this.size =0;
  26.  
  27.     }
  28.  
  29.     //定位
  30.     publicNode locate(int index) throws Exception
  31.     {
  32.         //容错性
  33.         if(index <-1|| index > size)
  34.             thrownewException("参数错误!");
  35.  
  36.         //定位到temp指向第index个(index为下标,从0开始)
  37.         Node temp = head;
  38.         for(int i =-1; i < index; i++)
  39.             if(temp != null)
  40.                 temp = temp.next;
  41.  
  42.         return  temp;
  43.     }
  44.  
  45.  
  46.     publicvoiddelete(int index) throws Exception{
  47.  
  48.         if(isEmpty())
  49.             thrownewException("链表为空,无法删除!");
  50.  
  51.         if(index <0|| index > size -1)
  52.             thrownewException("参数错误!");
  53.  
  54.         Node temp = locate(index -1);               //定位到要操作结点的前一个结点对象
  55.         temp.next = temp.next.next;
  56.         if(temp.next != null)                     //当删除到最后一个元素:temp.next == null
  57.             temp.next.prior = temp;
  58.         size--;
  59.     }
  60.  
  61.  
  62.     publicvoid insert(int index,Object obj) throws Exception{
  63.         //容错性
  64.         if(index <0|| index > size )
  65.             thrownewException("参数错误!");
  66.  
  67.         Node temp = locate(index -1);               //定位到要操作结点的前一个结点对象
  68.         Node p =newNode(obj,temp.next,temp);
  69.         temp.next = p;
  70.         if(p.next != null)                       //当插入到最后一个位置:p.next == null
  71.             p.next.prior = p;
  72.         size++;
  73.     }
  74.  
  75.     public boolean isEmpty(){
  76.         return size ==0;
  77.     }
  78.  
  79.     publicint size(){
  80.         returnthis.size;
  81.     }
  82.  
  83. }
 
  1. publicclassTest{
  2.  
  3.     publicstaticvoid main(String[] args) throws Exception{
  4.         DoubleLinkListlist=newDoubleLinkList();
  5.         for(int i =0; i <10; i++){
  6.             int temp =((int)(Math.random()*100))%100;
  7.             list.insert(i, temp);
  8.             System.out.print(temp +" ");
  9.         }
  10.  
  11.         list.delete(4);
  12.         System.out.println("\n"+"after deleting the 5th number:");
  13.         for(int i =0; i <list.size; i++){
  14.             System.out.print(list.locate(i).data.toString()+" ");
  15.         }
  16.     }
  17.  
  18. }
 
输出结果:
  1. 9588231885799228418
  2. after deleting the 5th number:
  3. 95882315799228418 
 
 
 
 
 

双向链表JAVA代码的更多相关文章

  1. 斐波那契堆(Fibonacci heap)原理详解(附java代码实现)

    前言 斐波那契堆(Fibonacci heap)是计算机科学中最小堆有序树的集合.它和二项式堆有类似的性质,但比二项式堆有更好的均摊时间.堆的名字来源于斐波那契数,它常用于分析运行时间. 堆结构介绍 ...

  2. 对一致性Hash算法,Java代码实现的深入研究

    一致性Hash算法 关于一致性Hash算法,在我之前的博文中已经有多次提到了,MemCache超详细解读一文中"一致性Hash算法"部分,对于为什么要使用一致性Hash算法.一致性 ...

  3. 怎样编写高质量的java代码

    代码质量概述     怎样辨别一个项目代码写得好还是坏?优秀的代码和腐化的代码区别在哪里?怎么让自己写的代码既漂亮又有生命力?接下来将对代码质量的问题进行一些粗略的介绍.也请有过代码质量相关经验的朋友 ...

  4. 数据结构笔记--二叉查找树概述以及java代码实现

    一些概念: 二叉查找树的重要性质:对于树中的每一个节点X,它的左子树任一节点的值均小于X,右子树上任意节点的值均大于X. 二叉查找树是java的TreeSet和TreeMap类实现的基础. 由于树的递 ...

  5. java代码的初始化过程研究

        刚刚在ITeye上看到一篇关于java代码初始化的文章,看到代码我试着推理了下结果,虽然是大学时代学的知识了,没想到还能做对.(看来自己大学时掌握的基础还算不错,(*^__^*) 嘻嘻……)但 ...

  6. JDBC——Java代码与数据库链接的桥梁

    常用数据库的驱动程序及JDBC URL: Oracle数据库: 驱动程序包名:ojdbc14.jar 驱动类的名字:oracle.jdbc.driver.OracleDriver JDBC URL:j ...

  7. 利用Java代码在某些时刻创建Spring上下文

    上一篇中,描述了如何使用Spring隐式的创建bean,但当我们需要引进第三方类库添加到我们的逻辑上时,@Conponent与@Autowired是无法添加到类上的,这时,自动装配便不适用了,我们需要 ...

  8. lombok 简化java代码注解

    lombok 简化java代码注解 安装lombok插件 以intellij ide为例 File-->Setting-->Plugins-->搜索"lombok plug ...

  9. 远程debug调试java代码

    远程debug调试java代码 日常环境和预发环境遇到问题时,可以用远程调试的方法本地打断点,在本地调试.生产环境由于网络隔离和系统稳定性考虑,不能进行远程代码调试. 整体过程是通过修改远程服务JAV ...

随机推荐

  1. Delphi 封装Frame到Dll文件

    做项目的时候,发现这个Frame很好用,为了省空间.调用和修改方便,就将Frame封装到dll(动态链接库)里面,确实很好使. 效果图如下: 上图是临时测试用的,忘了将Frame的align设置成al ...

  2. 自由创造属于你的H5内容

    在这里,你可以自由创造属于你的H5内容  mark下 http://www.ih5.cn/

  3. 读取url(1

    就书本例子 import java.io.InputStream; import java.net.URL; public class Test { public static void main(S ...

  4. UNIX基础知识

    一.线程 线程是进程某程序段的一次运行. 1.线程共享资源,利用共享的资源,线程很容易能够互相通信 (1)进程代码段:每个线程有各自的寄存器组,在运行时期拷贝给cpu寄存器,来确定运行的是哪段代码段. ...

  5. 交叉编译:cannot find /lib/libc.so.6 collect2: ld returned 1 exit status

    1.有时候明明指定了交叉编译的动态库搜索路径,但有些库提示还是搜索不到,而且提示的搜索路径有点奇怪,不是指定的路径,比如: /opt/mips-4.4/bin/../lib/gcc/mips-linu ...

  6. 深入浅出理解QTimeLine类

    网上找了下QTimeLIne类的介绍,要么就是代码一贴自己看去,要么就是说不到重点,正巧自己项目遇到这个类,在这里写一下,给需要的同学看下. 因为我最近需要有动画方面配合时间间隔触发QGraphics ...

  7. 关于表单的jQuery练习

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...

  8. 面向对象设计模式之Flyweight享元模式(结构型)

    动机:采用纯粹对象方案的问题在于大量细粒度的对象会很快充斥在系统中,从而带来很高的运行代价——主要指内存需求方面的代价.如何在避免大量细粒度对象问题的同 时,让外部客户程序仍然能够透明地使用面向对象的 ...

  9. 我牵头,你做事——C#委托实践

     我牵头,你做事——C#委托实践一 2007-09-05 23:54:54 标签:委托 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http ...

  10. ThinkInJava4读书笔记之第七章隐藏实施过程

    第7章 多形性 上溯造型:将一个对象作为它自己的类型使用,或者作为它的基础类型的一个对象使用.取得一个对象句柄,并将其作为基础类型句柄使用. 方法调用的绑定:将一个方法调用同一个方法主体连接到一起就称 ...