Java简单双向链表实现 @version 1.0
- package com.list;
- /**
- * 数据结构和算法Java表示 双向链表
- *
- * @version 1.0
- * @author 小明
- *
- */
- public class MyDoublelinkedlist {
- private DoubleNode head;// 头结点
- private DoubleNode end;// 尾结点
- private int size;// 长度
- // 构造函数
- public MyDoublelinkedlist() {
- head = null;// 头结点
- end = null;// 尾结点
- size = 0;// 长度为0
- }
- // 重写toString方法
- @Override
- public String toString() {
- DoubleNode temp = head;// 将头结点赋值给temp变量
- String str = " ";
- for (; temp != null;) {
- str += temp.getElement() + " ";// 字符串拼接
- temp = temp.getNext();// temp结点后移
- }
- str = "[" + str + " ]";
- return str;
- }
- // 插入方法,默认插入在链表的尾端
- public void add(DoubleNode dn) {
- if (size == 0) {// 长度为0,表为空,插入在表首
- head = dn;// 头结点被赋值
- end = dn;// 尾结点被赋值
- size++;// 长度加一
- } else {// 长度不为0,表不为空时,插入至表的最后一位
- end.setNext(dn);// 表尾的后继为插入元素
- dn.setPrev(end);// 插入元素的前驱为head
- end = dn;// 重新赋值表尾
- size++;
- }
- }
- // 插入方法,插入到指定的位置
- public void add(int index, DoubleNode dn) throws IndexException {
- DoubleNode temp = head;
- if (index <= 0 || index > size + 1) {// 插入位置不合理
- throw new IndexException("插入索引位置不合理");
- } else {// 插入位置合理
- if (size == 0) {// 表为空时,调用add默认函数来实现插入首位
- add(dn);
- return;
- }
- if (index == 1) {// 表不为空时插入位置在头结点
- head.setPrev(dn);// 设置头结点的前驱
- dn.setNext(head);// 设置新的头结点的后继
- head = dn;// 设置新的头结点
- size++;// 长度加一
- } else {// 索引合理,插入位置不在头结点
- if (index == size + 1) {// 插入索引在尾结点
- add(dn);// 使用默认add函数插入表尾
- return;
- } else {// 索引合理,插入不在头结点也不再尾结点
- for (int i = 1; i < index - 1; i++) {
- temp = temp.getNext();// 移至目标位置的前一位
- }
- dn.setNext(temp.getNext());// 完成插入节点的后继
- dn.setPrev(temp);// 完成插入节点的前驱
- temp.getNext().setPrev(dn);// 设置插入节点的后继的前驱
- temp.setNext(dn);// 完成插入节点的前驱的后继
- size++;// 长度加一
- }
- }
- }
- }
- /*
- * 删除函数
- */
- public void remove(int index) throws IndexException {
- DoubleNode temp = head;
- if (index <= 0 || index > size) {// 移除位置不合理
- throw new IndexException("删除位置不合理");
- } else {// 删除位置合理
- if (size == 0) {
- throw new IndexException("表为空无法删除");
- } else {// 删除位置合理且表不位空
- if (index == 1) {// 删除位置为头节点
- head.getNext().setPrev(null);// 设置新的节点为null
- head = head.getNext();// 设置新的节点
- size--;// 长度减一
- } else {// 删除位置合理且表不位空且删除位置不在头结点
- if (size == index) {// 删除位置合理且表不位空且删除位置不在头结点在尾结点
- for (; temp.getNext() != end;) {
- temp = temp.getNext();// 后移至倒数第二个结点
- }
- temp.setNext(null);// 删除表尾
- end = temp;// 新的表尾
- size--;// 长度减一
- } else {// 删除位置合理且表不位空且删除位置不在头结点也不再尾结点
- for (int i = 1; i < index - 1; i++) {
- temp = temp.getNext();
- }
- temp.setNext(temp.getNext().getNext());// 设置新的后继
- temp.getNext().setPrev(temp);// 设置新的前驱
- size--;// 长度减一
- }
- }
- }
- }
- }
- public static void main(String[] args) throws IndexException {
- MyDoublelinkedlist dl = new MyDoublelinkedlist();
- dl.add(new DoubleNode(1));
- dl.add(new DoubleNode(2));
- dl.remove(1);
- System.out.println(dl);
- }
- }
- /*
- * 双向链表的结点 一个值域,两个指针域
- */
- class DoubleNode<T> {
- private T element;// 值域
- private DoubleNode prev;// 前驱
- private DoubleNode next;// 后继
- // 构造函数
- public DoubleNode(T t) {
- element = t;
- prev = null;
- next = null;
- }
- public void setPrev(DoubleNode dn) {
- prev = dn;
- }
- public void setNext(DoubleNode dn) {
- next = dn;
- }
- public DoubleNode getPrev() {
- return prev;
- }
- public DoubleNode getNext() {
- return next;
- }
- public T getElement() {
- return element;
- }
- }
Java简单双向链表实现 @version 1.0的更多相关文章
- 版本问题 Java:Unsupported major.minor version 51.0 (unable to load class . . .
导入别人的项目时报错 Java:Unsupported major.minor version 51.0 (unable to load class . . . 后发现错误是由于class编译器的J ...
- [java] Unsupported major.minor version 51.0 错误解决方案
jdk1.6工程中使用外部jar包中类出现:Unsupported major.minor version 51.0原因分析:出现上述错误是因为:外部jar包使用jdk1.7(jdk7)编译,而使用此 ...
- java unsupported major.minor version 51.0 解决
1.概述 出现如题所述异常 是因为jdk高版本 编译后的class文件 运行在低版本的jre环境下(如jdk7编译 运行在jdk6环境下) 2. 解决方案 在eclipse等ide中重新编译 指定编译 ...
- java运行报错 has been compiled by a more recent version of the Java Runtime (class file version 55.0), this version of the Java Runtime only recognizes class file versions up to 52.0
解决方法: 解决办法: 在项目的属性里设置jdk版本,方法是右击项目-->properties-->java compiler --> Enable project specific ...
- (class file version 53.0), Java Runtime versions up to 52.0错误的解决方法
遇到这个错误是在Apache Tomcat上部署应用程序的时候遇到的,具体的错误描述是: java.lang.UnsupportedClassVersionError: HelloWorld has ...
- [JAVA] 一个可以编辑、编译、运行Java简单文件的记事本java实现
本来是Java课做一个仿windows记事本的实验,后来突然脑子一热,结果就给它加了一个编译运行Java文件的功能. 本工程总共大约3000行代码,基本上把所学的java界面.文件.控件的功能都包含在 ...
- Java单链表简单实现* @version 1.0
package com.list; /** * 数据结构与算法Java表示 * @version 1.0 * @author 小明 * */ public class MyLinkedList { p ...
- java程序无法启动:Unsupported major.minor version 51.0
今天在sae上部署了一个项目,结果总是出现503错误:service unavailable,然后jvm出现了一大串错误日志,如下 JAVA_SAE_Fatal_error: Failed start ...
- Java运行 Unsupported major.minor version 51.0 错误
今天写了简单的Java程序,运行的时候不知道为啥出现这个问题 happy@happy-HP-Compaq-dx7518-MT:~/Study/CrazyJava$ java FieldTest Exc ...
随机推荐
- [poj 2453] An Easy Problem
An Easy Problem Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8371 Accepted: 5009 D ...
- Utils--前台调用后台接口工具类
Utils--前台调用后台接口工具类 package com.taotao.manage.httpclient; import java.io.IOException; import java.net ...
- iOS 时间校准解决方案
背景 在 iOS 开发中,凡是用到系统时间的,都要考虑一个问题:对时.有些业务是无需对时,或可以以用户时间为准的,比如动画用到的时间.一些日程类应用等.但电商相关的业务大都不能直接使用设备上的时间,而 ...
- Oracle 12c启动时PDBs的自动打开
Pluggable Database(PDB)为Oracle 12c中的一个重要的新特性, 但启动12c实例时并不会自动打开PDB数据库,这样,在启动实例后必须手动打开PDBs. 1. 实例启动后,手 ...
- springboot自动装配
Spring Boot自动配置原理 springboot自动装配 springboot配置文件 Spring Boot的出现,得益于“习惯优于配置”的理念,没有繁琐的配置.难以集成的内容(大多数流行第 ...
- MySQL升级教程(CentOS)
1.支持的升级方式 原地升级(In-Place Upgrade):直接替换二进制文件(即直接yum update/rpm -Uvh升级rpm包)数据库目录等都不变. 逻辑升级(Logical Upgr ...
- 在springboot中验证表单信息(六)
构建工程 创建一个springboot工程,由于用到了 web .thymeleaf.validator.el,引入相应的起步依赖和依赖,代码清单如下: 1 2 3 4 5 6 7 8 9 10 11 ...
- 逆袭之旅DAY24.XIA.数组练习
2018-07-20 08:40:19 1. public void stringSort(){ String[] s = new String[]{"George"," ...
- java的八大排序
public class Sort2 { public static void main(String[] args) { Sort2 sort = new Sort2(); System.out.p ...
- hdu3377
题解: 简单的插头dp 加上一个代价即可 代码: #include<cstdio> #include<cmath> #include<cstring> #inclu ...