1. 定义节点node

public class Node<T> {

	private Node<T> pre;

	private Node<T> next;

	private T data;

	public void setPre(Node<T> node){
this.pre = node;
} public Node<T> getPre(){
return pre;
} public void setNext(Node<T> node){
this.next = node;
} public Node<T> getNext(){
return next;
} public void setData(T data){
this.data = data;
} public T getData(){
return this.data;
} public Node(Node<T> pre, Node<T> next, T data){
this.pre = pre;
this.next = next;
this.data = data;
} public Node(){
super();
}
}

2.  创建链表方式1,与c++类似

public class ListDirectNode<T extends Comparable<T>> {

	private byte[] lock = new byte[1];

	/**
* 链表大小
*/
private int size; /**
* 链表头节点
*/
private Node<T> header; /**
* 链表尾部节点
*/
private Node<T> tail; public void setHeader(Node<T> node){
this.header = node;
} public Node<T> getHeader(){
return this.header;
} public void setTail(Node<T> node){
this.tail = node;
} public Node<T> getTail(){
return this.tail;
} public int size(){
return this.size;
} public ListDirectNode(){
size = 0;
header = new Node<T>(null, null, null);
tail = new Node<T>(header, null, null);
header.setNext(tail);
} /**
* 往链表尾部追加数据
* @param data
*/
public void add(T data){
synchronized (lock) {
Node<T> node = new Node<T>(null, null, data);
tail.getPre().setNext(node);
node.setPre(tail);
node.setNext(tail);
tail.setPre(node);
size++;
}
} /**
* @param sortType 排序方式
* true:升序
* false:降序
*/
public void sort(boolean sortType){
for(Node<T> node1 = header.getNext(); node1.getNext() != tail; node1 = node1.getNext()){
for(Node<T> node2 = node1.getNext(); node2 != tail; node2 = node2.getNext()){
T d1 = node1.getData();
T d2 = node2.getData();
if(sortType){
if(compare(d1, d2) > 0){
node1.setData(d2);
node2.setData(d1);
}
}else{
if(compare(d1, d2) < 0){
node1.setData(d2);
node2.setData(d1);
}
}
}
}
} private int compare(T d1, T d2){
return d1.compareTo(d2);
} public boolean isEmpty(){
return size==0;
} public T get(int index){
if(index > size || index < 0){
throw new IndexOutOfBoundsException();
}
Node<T> currentNode = new Node<T>(header, null, null);
for(int i=1; i<=index; i++){
currentNode = currentNode.getNext();
}
return currentNode.getData();
} public void print(){
int index = 0;
Node<T> currentNode = header.getNext();
while(currentNode.getNext() != null){
index++;
System.out.println("当前位置:"+index+",当前值"+currentNode.getData().toString());
currentNode = currentNode.getNext();
}
}
}

3. 创建链表方式2,迭代器

public class MyList<T extends Comparable<T>> implements Iterable<T>{

	/**
* 链表大小
*/
private int size; /**
* 链表头节点
*/
private Node<T> header; /**
* 链表下一节点
*/
private Node<T> tail; public void setHeader(Node<T> node){
this.header = node;
} public Node<T> getHeader(){
return this.header;
} public void setTail(Node<T> node){
this.tail = node;
} public Node<T> getTail(){
return this.tail;
} public int size(){
return this.size;
} public MyList(){
size = 0;
header = new Node<T>(null, null, null);
tail = new Node<T>(header, null, null);
header.setNext(tail);
} public void add(T data){
Node<T> node = new Node<T>(null, null, data);
tail.getPre().setNext(node);
node.setPre(tail);
node.setNext(tail);
tail.setPre(node);
size++;
} /**
* @param sortType 排序方式
* true:升序
* false:降序
*/
public void sort(boolean sortType){
for(Node<T> node1 = header.getNext(); node1.getNext() != tail; node1 = node1.getNext()){
for(Node<T> node2 = node1.getNext(); node2 != tail; node2 = node2.getNext()){
T d1 = node1.getData();
T d2 = node2.getData();
if(sortType){
if(compare(d1, d2) > 0){
node1.setData(d2);
node2.setData(d1);
}
}else{
if(compare(d1, d2) < 0){
node1.setData(d2);
node2.setData(d1);
}
}
}
}
} private int compare(T d1, T d2){
return d1.compareTo(d2);
} public void print(){
int index = 0;
Iterator<T> iterator = this.iterator();
while(iterator.hasNext()){
index++;
System.out.println("当前位置:"+index+",当前值"+iterator.next().toString());
}
} @Override
public Iterator<T> iterator() {
return new MyListIterator<T>();
} private class MyListIterator<T> implements Iterator<T>{ @SuppressWarnings("unchecked")
Node<T> current = (Node<T>) header.getNext(); @Override
public boolean hasNext() {
return current != tail;
} @Override
public T next() {
if(!hasNext()){
throw new IndexOutOfBoundsException();
}
T data = current.getData();
current = current.getNext();
return data;
} @Override
public void remove() {
if(!hasNext()){
throw new NoSuchElementException();
}
current.getPre().setNext(current.getNext());
current.getNext().setPre(current.getPre());
current = current.getNext();
size--;
}
}
}

4. 测试代码

public class TestMain {

	public static void main(String[] args){
ListDirectNode<String> list = new ListDirectNode<String>();
list.add("a");
list.add("d");
list.add("b");
list.add("e");
list.sort(true);
list.print(); MyList<String> list2 = new MyList<String>();
list2.add("a1");
list2.add("d1");
list2.add("b1");
list2.add("e1");
list2.sort(true);
list2.print(); ListDirectNode<Integer> list3 = new ListDirectNode<Integer>();
list3.add(1);
list3.add(3);
list3.add(2);
list3.add(10);
list3.sort(false);
list3.print(); MyList<Integer> list4 = new MyList<Integer>();
list4.add(10);
list4.add(3);
list4.add(6);
list4.add(0);
list4.sort(false);
list4.print();
}
}

java实现链表结构的更多相关文章

  1. (原创)用Java实现链表结构对象:单向无环链表

    转载请注明本文出处:http://www.cnblogs.com/Starshot/p/6918569.html 链表的结构是由一个一个节点组成的,所谓链,就是每个节点的头尾连在一起.而单向链表就是: ...

  2. java实现链表结构详细代码

    一.数据准备 1. 定义节点 2.   定义链表 1.数据部分 2.节点部分 class DATA //数据节点类型 { String key; String name; int age; } cla ...

  3. Java实现链表结构的具体代码

    一.数据准备 1. 定义节点 2.   定义链表 1.数据部分 2.节点部分 class DATA //数据节点类型 { String key; String name; int age; } cla ...

  4. JAVA基础——链表结构之单链表

    链表:一种数据存储结构.学链表首先要搞懂数组,按朋友的话说,数组和链表的关系就相当于QQ2008和QQ2009. 除非要通过索引频繁访问各个数据,不然大多数情况下都可以用链表代替数组. 链表部分主要要 ...

  5. JAVA基础——链表结构之双端链表

    双端链表:双端链表与传统链表非常相似.只是新增了一个属性-即对最后一个链结点的引用 如上图所示:由于有着对最后一个链结点的直接引用.所以双端链表比传统链表在某些方面要方便.比如在尾部插入一个链结点.双 ...

  6. 《Java数据结构》链表结构(单向链表,双向链表)

    单向链表(单链表)是链表的一种,其特点是链表的链接方向是单向的,对链表的访问要通过顺序读取从头部开始:链表是使用指针进行构造的列表:又称为结点列表,因为链表是由一个个结点组装起来的:其中每个结点都有指 ...

  7. java数据结构--线性结构

    一.数据结构 数据结构由数据和结构两部分组成,就是将数据按照一定的结构组合起来,这样不同的组合方式有不同的效率,可根据需求选择不同的结构应用在相应在场景.数据结构大致 分为两类:线性结构(如数组,链表 ...

  8. java单链表常用操作

    总结提高,与君共勉 概述. 数据结构与算法亘古不变的主题,链表也是面试常考的问题,特别是手写代码常常出现,将从以下方面做个小结 [链表个数] [反转链表-循环] [反转链表-递归] [查找链表倒数第K ...

  9. java资料——链表(转)

    链表 链表是一种物理存储单元上非连续.非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的.链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成.每个结点包括两个 ...

随机推荐

  1. C++单元测试2

    这里再对上一篇<C++单元测试>进行技巧补充. 我们知道对动态链接库(lib和dll)的测试是比较简单的,我这里主要对需要注意的地方说明一下. 1.建议单独创建单元测试解决方案(不是创建项 ...

  2. 关于 const 成员函数

    成员函数如果是const意味着什么? 有两个流行概念:物理常量性和逻辑常量性. C++对常量性的定义采用的是物理常量性概念,即const 成员函数不可以更改对象内任何non-static成员变量.例如 ...

  3. 24种设计模式--命令模式【Command Pattern】

    今天讲命令模式,这个模式从名字上看就很简单,命令嘛,老大发命令,小兵执行就是了,确实是这个意思,但是更深化了,用模式来描述真实世界的命令情况.正在看这本书的你,我猜测分为两类:已经工作的和没有工作的, ...

  4. easy ui tree 取父节点的值和取蓝色框的值

    var nodes = $('#basetree').tree('getChecked'); var cnode = ''; var fnode = ''; for ( var i = 0; i &l ...

  5. 经典SQL练习题

    题目地址:http://blog.csdn.net/qaz13177_58_/article/details/5575711 1. 查询Student表中的所有记录的Sname.Ssex和Class列 ...

  6. 2013年12月26日 星期四 doxygen入门--很好

    body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...

  7. excel快递单号查询工具以及源码

    Function kdcx(kd, orderid) Dim Err, url, kdtime, link, Errcode, Status Select Case kd '此处支持的快递公司很多的 ...

  8. iPhone分辨率

    分辨率和像素 1.iPhone5           4"     分辨率320x568,像素640x1136,@2x 2.iPhone6           4.7"  分辨率3 ...

  9. 【读书笔记】【CLR via C#】【第一章】The CLR’s Execution Model

    内容提要 本章的目的是对.Net 框架的设计做一个总体的介绍,包括介绍框架中使用的一些技术.定义一些术语.同时会展示从源代码生成应用程序(或者一些包含了一些自定义类型的可以发布的组件),并且会解释程序 ...

  10. WPF Window异形窗口演示

    我们先通过简单的效果展示,切换展示不同图片: 我们先定义图片资源文件,我们可以在window资源中定义,下面的在app.xaml文件来定义: <Application x:Class=" ...