javaSE基础之 LinkedList的底层简单实现
这里贴上LinkedList底层的简单实现
package com.yck.mylinkedlist;
public class Node
{
    private Node previous; //上一结点
    private Object object; //本结点所存储的东西
    private Node next;    //下一个结点
    public Node(){}
    public Node(Node previous, Object object, Node next)
    {
        super();
        this.previous = previous;
        this.object = object;
        this.next = next;
    }
    public Node getPrevious()
    {
        return previous;
    }
    public void setPrevious(Node previous)
    {
        this.previous = previous;
    }
    public Object getObject()
    {
        return object;
    }
    public void setObject(Object object)
    {
        this.object = object;
    }
    public Node getNext()
    {
        return next;
    }
    public void setNext(Node next)
    {
        this.next = next;
    }
}
package com.yck.mylinkedlist;
/**
 * 手动实现LinkedList底层,这次用了泛型
 * @author Administrator
 *
 * @param <T>
 */
public class MyLinkedList<T>
{
    private Node first;
    private Node last;
    private int size;
    public MyLinkedList(){}
    public void add(T t)
    {
        Node n =new Node();
        if(first == null)
        {
            n.setPrevious(null);
            n.setObject(t);
            n.setNext(null);
            first = n;
            last = n;
            size++;
        }
        else
        {
            n.setPrevious(last);
            n.setObject(t);
            n.setNext(null);
            last.setNext(n);
            last = n;
            size++;
        }
    }
    public void add(int index,T t)
    {
        rangCheck(index);
        Node temp = new Node();
        if(index == 0)
        {
            temp.setPrevious(null);
            temp.setObject(t);
            temp.setNext(first);
            first = temp;
        }
        else if(index != size)
        {
            temp.setPrevious(getNode(index-1));
            temp.setObject(t);
            temp.setNext(getNode(index));
            getNode(index-1).setNext(temp);
            getNode(index).setPrevious(temp);
        }
        else
        {
            temp.setPrevious(last);
            temp.setObject(t);
            temp.setNext(null);
            last = temp;
        }
        size++;
    }
    public void add(MyLinkedList<T> list)
    {
        Node temp = new Node();
        temp = list.first;
        temp.setPrevious(this.last);
        this.last.setNext(temp);
        this.last = list.last;
        this.size += list.size;
        list.first.setPrevious(null);
    }
    public void remove(int index)
    {
        getNode(index - 1).setNext(getNode(index+1));;
        getNode(index).setPrevious(getNode(index -1));
        size--;
    }
    public Node getNode(int index)
    {
        rangCheck(index);
        Node temp = new Node();
        temp=first;
        for(int i=0;i<index;i++)
        {
            temp=temp.getNext();
        }
        return temp;
    }
    public Object get(int index)
    {
        return getNode(index).getObject();
    }
    public void rangCheck(int index)
    {
        if(index<0 || index>=this.size)
            try
        {
                throw new Exception();
        }
        catch (Exception e)
        {
                // TODO Auto-generated catch block
                e.printStackTrace();
        }
    }
    public static void main(String[] args)
    {
        MyLinkedList<String> list = new MyLinkedList<String>();
        list.add("aaa");
        list.add("ooo");
        list.add("xxx");
        list.add("fff");
        for(int i=0;i<list.size;i++)
            System.out.println(list.get(i));
        System.out.println("****************");
        list.remove(2);
        for(int i=0;i<list.size;i++)
            System.out.println(list.get(i));
        System.out.println("****************");
        MyLinkedList<String> list1 = new MyLinkedList<String>();
        list1.add("I");
        list1.add("love");
        list1.add("u");
        System.out.println(list1.first.getPrevious());
        System.out.println("****************");
        for(int i=0;i<list1.size;i++)
            System.out.println((String)list1.get(i));
        System.out.println("****************");
        list.add(list1);
        for(int i=0;i<list.size;i++)
            System.out.println((String)list.get(i));
        System.out.println("****************");
    }
}
差点忘记贴上面简单测试的结果了

javaSE基础之 LinkedList的底层简单实现的更多相关文章
- javaSE基础之 ArrayList的底层简单实现
		最近就是想扒一扒存在硬盘里面的学习资料(突然想到什么),把以前写过的一些东西整理一下分享出来. 这边是ArrayList 的简单实现,当然只实现了部分方法 package com.yck.collec ... 
- javase基础回顾(二)LinkedList需要注意的知识点 阅读源码收获
		我们在学习这一块内容时需要注意的一个问题是 集合中存放的依然是对象的引用而不是对象本身. List接口扩展了Collection并声明存储一系列元素的类集的特性.使用一个基于零的下标,元素可以通过它们 ... 
- 基础1 JavaSe基础
		JavaSe基础 1. 九种基本数据类型的大小,以及他们的封装类 boolean 无明确指定 Boolean char 16bits Character byte 8bits Byte short 1 ... 
- java学习之路之javaSE基础1
		<h2>java学习之路之javaSE基础1</h2> <div> ###01.01_计算机基础知识(计算机概述)(了解)* A:什么是计算机?计算机在生活中的应用 ... 
- JavaSE基础:集合类
		JavaSE基础:集合类 简单认识类集 我们学习的是面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,我们就必须把这多个对象进行存储. 而要向存储多个对象,就不能是 ... 
- javaSE基础07
		javaSE基础07 一.static静态修饰符 用了static修饰的变量就会变成共享的属性,只会初始化一次,在内存中只存在一个,并且每个对象都可以访问,存放在方法区(数据共享区) 1.1 stat ... 
- javaSE基础06
		javaSE基础06 一.匿名对象 没有名字的对象,叫做匿名对象. 1.2匿名对象的使用注意点: 1.我们一般不会用匿名对象给属性赋值的,无法获取属性值(现阶段只能设置和拿到一个属性值.只能调用一次方 ... 
- javase基础复习攻略《二》
		今天就开始的真正走进JAVASE的世界,本篇介绍的是:JAVASE基础语法,大家如果有C语言的基础,对于本节内容一定感觉非常轻松,编程语言之间的都是相通的,只不过C语言属于面向过程编程,而JAVA语言 ... 
- java学习之路之javaSE基础2
		java学习之路之javaSE基础2 所有的代码都是引用他人写的. 1.逻辑运算符 //&,|,^,! //int x = 10; //5 < x < 15 //x > 5 ... 
随机推荐
- 【高斯消元】兼 【期望dp】例题
			[总览] 高斯消元基本思想是将方程式的系数和常数化为矩阵,通过将矩阵通过行变换成为阶梯状(三角形),然后从小往上逐一求解. 如:$3X_1 + 2X_2 + 1X_3 = 3$ $ ... 
- NLP —— 图模型(三)pLSA(Probabilistic latent semantic analysis,概率隐性语义分析)模型
			LSA(Latent semantic analysis,隐性语义分析).pLSA(Probabilistic latent semantic analysis,概率隐性语义分析)和 LDA(Late ... 
- 如何修改script.bin/script.fex
			你是否经常看见其他帖子里或者其他人提到要修改script.bin或script.fex ,但你又不知道怎么改. 其实 script.bin就是script.fex通过 fex2bin生成的,scrip ... 
- eclipse中console的输出行数控制
			eclipse中console的输出行数控制 开发中,会遇到当输出大量的sql语句或者错误的时候,往往会因为console输出的限制而不能完整显示,所以我们自己就需要迫切的增加显示的行数,这样 就可以 ... 
- 踩坑之路_"var name = ' ';"_迷之BUG
			情景介绍:最近写一个拖拽生成图表的工具,自己的思路每次mousedown的时候动态将this的name属性值赋值给全局中变量(自己手贱测试时直接将变量名命名为了'name',一大波bug还有30s到达 ... 
- java_AWT常用组件
			Button:按钮,可接受单击操作. Canvas:用于绘图的画布. Checkbox:复选框组件(也可以变成单选框组件). CheckboxGroup:用于将多个Checkbox组件合成一组,一组C ... 
- Linux(7)chmod解析
			在UNIX和Linux的操作系统中, 每个文件(文件夹也被看作是文件)都按读, 写, 运行设定权限 比如用ls -l或ll命令列文件表时, 得到如下输出: -rw-r--r-- 1 apple use ... 
- POJ1975 Median Weight Bead  floyd传递闭包
			Description There are N beads which of the same shape and size, but with different weights. N is an ... 
- 拓扑排序下的有无环判定 STL方法
			bool canFinish(int numCourses, vector<pair<int, int>>& prerequisites) { vector<se ... 
- Java 库:为 Java 程序员而生的 10 + 最佳库
			众所周知,Java 的生态环境相当庞大,包含了数量相当可观的官方及第三方库.利用这些库,可以解决在用 Java 开发时遇到的各类问题,让开发效率得到显著提升. 举些例子,最常用的官方库有 java.l ... 
