Java双向链表实现
public class DoublyLinkList {
private class Data{
private Object obj;
private Data left = null;
private Data right = null; Data(Object obj){
this.obj = obj;
}
} private Data first = null;
private Data last = null; public void insertFirst(Object obj){
Data data = new Data(obj);
if(first == null){
last = data;
}else{
data.right = first;
first.left = data;
}
first = data;
} public void insertLast(Object obj){
Data data = new Data(obj);
if(first == null){
first = data;
}else{
data.left = last;
last.right = data;
}
last = data;
} public boolean insertAfter(Object target,Object obj){
Data data = new Data(obj);
Data cur = first;
while(cur != null){
if(cur.obj.equals(target)){
data.right = cur.right;
data.left = cur;
if(cur == last)
last = data;
else
cur.right.left = data;
cur.right = data;
return true;
}
cur = cur.right;
}
return false;
} public Object deleteFirst() throws Exception{
if(first == null)
throw new Exception("empty!");
Data temp = first;
if(first.right == null){
first = null;
last = null;
}else{
first.right.left = null;
first = first.right;
}
return temp;
} public Object deleteLast() throws Exception{
if(first == null)
throw new Exception("empty!");
Data temp = last;
if(first.right == null){
first = null;
last = null;
}else{
last.left.right = null;
last = last.left;
}
return temp;
} public Object delete(Object obj) throws Exception{
if(first == null)
throw new Exception("empty!");
Data cur = first;
while(cur != null){
if(cur.obj.equals(obj)){
if(cur == last)
last = cur.left;
else
cur.right.left = cur.left;
if(cur == first)
first = cur.right;
else
cur.left.right = cur.right;
return obj;
}
cur = cur.right;
}
return null;
} public void display(){
System.out.print("first -> last : ");
Data data = first;
while(data != null){
System.out.print(data.obj.toString() + " -> ");
data = data.right;
}
System.out.print("\n");
} public static void main(String[] args) throws Exception{
DoublyLinkList dll = new DoublyLinkList();
dll.insertFirst(1);
dll.insertLast(3);
dll.insertAfter(1, 2);
dll.insertAfter(3, 4);
dll.insertAfter(4, 5);
dll.display();
dll.deleteFirst();
dll.display();
dll.deleteLast();
dll.display();
dll.delete(3);
dll.display();
dll.delete(2);
dll.display();
dll.delete(4);
dll.display();
}
}
first -> last : 1 -> 2 -> 3 -> 4 -> 5 ->
first -> last : 2 -> 3 -> 4 -> 5 ->
first -> last : 2 -> 3 -> 4 ->
first -> last : 2 -> 4 ->
first -> last : 4 ->
first -> last :
Java双向链表实现的更多相关文章
- JAVA双向链表
1.链表是一种重要的数据结构,在程序设计中占有很重要的地位 2.我们可以用类List来实现链表结构,用变量Head.Tail.Length.Pointer来实现表头.存储当前结点的指针时有一定的技 巧 ...
- Spark案例分析
一.需求:计算网页访问量前三名 import org.apache.spark.rdd.RDD import org.apache.spark.{SparkConf, SparkContext} /* ...
- JAVA单向/双向链表的实现
一.JAVA单向链表的操作(增加节点.查找节点.删除节点) class Link { // 链表类 class Node { // 保存每一个节点,此处为了方便直接定义成内部类 private Str ...
- 数组、单链表和双链表介绍 以及 双向链表的C/C++/Java实现
概要 线性表是一种线性结构,它是具有相同类型的n(n≥0)个数据元素组成的有限序列.本章先介绍线性表的几个基本组成部分:数组.单向链表.双向链表:随后给出双向链表的C.C++和Java三种语言的实现. ...
- 大话数据结构(八)Java程序——双向链表的实现
线性链表--双向链表 双向链表定义: 双向链表(double linked list): 是在单表单的每个结点中,再设置一个指向前驱结点的指针域.因此,在双向链表中的结点都有两个指针域,一个指向前驱, ...
- 线性链表的双向链表——java实现
.线性表链式存储结构:将采用一组地址的任意的存储单元存放线性表中的数据元素. 链表又可分为: 单链表:每个节点只保留一个引用,该引用指向当前节点的下一个节点,没有引用指向头结点,尾节点的next引用为 ...
- Java中双向链表的代码实现
写在前面: 双向链表是一种对称结构,它克服了单链表上指针单向性的缺点,其中每一个节点即可向前引用,也可向后引用,这样可以更方便的插入.删除数据元素. 由于双向链表需要同时维护两个方向的指针,因此添加节 ...
- 双向链表--Java实现
/*双向链表特点: *1.每个节点含有两个引用,previos和next,支持向前或向后的遍历(除头节点) *2.缺点插入或删除的时候涉及到引用修改的比较多 *注意:下面的双向链表其实也实现了双端链表 ...
- JAVA实现双向链表的增删功能
JAVA实现双向链表的增删功能,完整代码 package linked; class LinkedTable{ } public class LinkedTableTest { //构造单链表 sta ...
随机推荐
- Git管理命令
1.创建分支 git branch <分支名> 2.切换分支 git checkout <分支名> 创建并切换到该分支:git checkout -b <分支名> ...
- 《Oracle Database 12c DBA指南》第一章 - 基本技能简介
当前关于12c的中文资料比较少,本人将关于DBA的一部分官方文档翻译为中文,很多地方为了帮助中国网友看懂文章,没有按照原文句式翻译,翻译不足之处难免,望多多指正. 1 基本技能简介 作为一个数据库管理 ...
- 【译】 AWK教程指南 附录C-AWK的内建函数
C.1 字串函数 index( 原字串, 查找的子字串 ) 若原字串中含有欲寻找的子字串,则返回该子字串在原字串中第一次出现的位置,若未曾出现该子字串则返回0. 例如: $ awk 'BEGIN{ p ...
- ASP.NET_验证控件(class0620)
为什么使用验证控件 当需要让用户输入数据时,用户有可能输入不符合我们程序逻辑要求的信息,所以我们要对输入进行验证. 客户端验证(用户体验,减少服务器端压力) 服务器端验证(防止恶意攻击,客户端js很容 ...
- SimpleHttpServer的学习(1)
闲来没事,分析一下一个简单的HttpServer github地址: https://github.com/Filirom1/SimpleHTTPServer 实现的功能很简单就是一个FTP服务器 默 ...
- bzoj 1835 [ZJOI2010]base 基站选址(DP+线段树)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1835 [题意] 有n个村庄,每个村庄位于d[i],要求建立不多于k个基站,在第i个村庄 ...
- C/C++动态分配与释放内存的区别详细解析
以下是对C与C++中动态分配与释放内存的区别进行了详细的分析介绍,需要的朋友可以过来参考下 1. malloc()函数1.1 malloc的全称是memory allocation,中文叫动态内存分配 ...
- 清空具有外键约束的表时报ERROR 1701(42000)的解决办法
ERROR 1701 (42000): Cannot truncate a table referenced in a foreign key constraint (`furion`.`tbl_fr ...
- JavaScript:子ウィンドウから親ウィンドウを再読み込みさせる方法
ことの起こり Webの画面では.新規入力をしようとすると.別ウィンドウ=子ウィンドウが開いて入力し.登録ボタンを押すと.子ウィンドウが閉じる仕組みがある. 子ウィンドウが閉じるだけなら問題ないが.一覧 ...
- C语言不支持默认参数,不过可以用宏来模拟
C语言不支持默认参数,不过可以用宏来模拟: //--------------------------------------------------------------------------- ...