链表是用指针将多个节点联系在一起,通过头节点和尾节点还有节点数量,可以对链表进行一系列的操作。是线性表的链式存储实现。

1.链表是多个不连续的地址组成在一起根据指针链接在一起的,由多个节点组成,每个节点包括元素域和指针域
2.元素域存储节点数组,指针域存储下一节点指针
3.我们对链表的操作都是间接的通过链表头节点操作来实现的
4.一个链表中有多个节点,一个节点包括元素域,和下一节点指针域
5.最左边的节点是头节点,但是添加节点是从右到左添加,新添加的节点会被作为头节点
6.链表是由不定数量的节点连接(通过相互之间的引用)起来的,由于这种关系,在链表里我们只定义了头节点和节点数量。节点是由存储的对象及对下一个“节点”的引用封装而成。
7.在添加节点到链表中时,首先添加的节点后置后,新添加的节点作为头节点引用前一个添加的节点。

//先创建一个节点类

 package linkedList;
//节点类
public class Node<E> {
protected Object data = null; //数据域
protected Node<E> next = null; //指针域 //初始化数据域
public Node(E e, Node<E> next) {
this.data = e; //初始化数据域
this.next = next; //初始化指针域
} //显示节点,获取当前实体对象,数据域
public Object getData(){
return this.data;
} //获取下一个实体,指针域
public Node<E> getNext(){
return this.next;
} @Override
public String toString() {
return "Node [data=" + data + ", next=" + next + "]";
} }

//然后创建我们的链表类,将节点作为链表的属性

 package linkedList;

 import java.util.ArrayList;
import java.util.List; /**
* 1.链表是多个不连续的地址组成在一起根据指针链接在一起的,由多个节点组成,每个节点包括元素域和指针域
* 2.元素域存储节点数组,指针域存储下一节点指针
* 3.我们对链表的操作都是间接的通过链表头节点操作来实现的
* 4.一个链表中有多个节点,一个节点包括元素域,和下一节点指针域
* 5.最左边的节点是头节点,但是添加节点是从右到左添加,新添加的节点会被作为头节点
* 6.链表是由不定数量的节点连接(通过相互之间的引用)起来的,由于这种关系,在链表里我们只定义了头节点和节点数量。节点是由存储的对象及对下一个“节点”的引用封装而成。
* 7.在添加节点到链表中时,首先添加的节点后置后,新添加的节点作为头节点引用前一个添加的节点。
* @author LH-PC
*
*/
public class LinkedList<E> implements java.io.Serializable{
private static final long serialVersionUID = 1L; private Node<E> head; //头节点
private int size; //节点数量,即链表长度 //添加头节点 在添加链表节点时,首先添加的节点(头节点)后置,新添加的节点变成头节点,并且执向前一个头节点
public void addNode(E e){
//判断链表中有无该对象:从头节点开始遍历,匹配有无此对象
//如果有头节点,则添加新的节点为头节点,新的头节点指向上一个头节点
if(head != null){
System.out.println("链表中已经存在头节点, 正在添加新的头节点:" + e);
System.out.println("添加成功! 此头节点指向->" + head.data);
this.head = new Node<E>(e, head); //将新添加的节点作为头节点,指针域指向上一个头节点
size ++; //节点数量++ }else {
//如果没有头节点,则添加新的对象作为头节点,第一个头节点指向null
System.out.println("链表中不存在头节点,正在添加头节点:" + e);
this.head = new Node<E>(e, null);
System.out.println("添加成功!头节点指向->" + null);
size ++; //节点数量++
}
} //在指定位置插入节点
public int insert(int index, E e){
Node<E> temp = this.head;
int i = 0;
if(index < i || i > this.size){
System.err.println("索引大于链表长度或者小于0:" + index);
return -1;
} if(index == 0){
//如果index == 0,插入到头节点之后
this.head.next = new Node<E>(e, head.next); //将头节点指向新节点,将新节点指向原来头节点的下一个节点
size ++; //节点数量加1
return 1;
} //遍历链表
while(temp != null){
//运动到了指定位置
if(index == i){
temp.next = new Node<E>(e, temp.next); //将插入进来的指针域指向当前节点,将当前节点的上一个节点指针域指向当前节点
size ++; //节点长度加1
break;
}
temp = temp.next; //向下一个节点运动
i ++;
} return 1;
} //删除头节点
public void deleteByHead(){
//1.找到头节点。this.head
//2.更新头节点。将当前链表头节点设置为删除头节点的指针域
//3.链表节点数量-1
System.out.println("正在删除头节点:" + this.head.getData());
this.head = this.head.next; //更新头节点为下一节点
size --; //节点数量-1
System.out.println("删除成功"); } //删除指定位置的节点
public void deleteByIndex(int index){
//找到指定位置的前一个节点,将前一个节点指向后面两个节点。中间的节点就将被删除了。
Node<E> temp = this.head;
int i = 0;
if(index < i || index > this.size){
System.err.println("索引不能小于0或大于链表长度:" + index);
return;
} //如果索引为0,表示删除头节点
if( index == 0){
this.deleteByHead(); //调用删除头节点方法
return;
} //遍历链表
while(temp != null){
//找到目标节点的上一个节点
if(index-1 == i){
System.out.println("正在删除节点:" + this.head.next.getData());
temp.next = temp.next.next;
System.out.println("删除成功");
size --; //节点数减1
return;
}
temp = temp.next; //继续遍历
i ++;
} } //更新指定位置的节点
public void updateByIndex(int index, E e){
if(index < 0 || index > this.size){
System.err.println("索引小于0或者大于链表长度:" + index);
} // if(index == 0){
// this.updateByHead(e); //如果index==0,更新头节点
// } //遍历链表
int i = 0;
Node<E> temp = this.head;
while(temp != null){
if(index == i){
temp.data = e;
break;
}
temp = temp.next;
i ++;
} } //更新头节点
public void updateByHead(E e){
this.head.data = e; //为头节点重新赋值
} //打印链表中的所有数据 从头节点一直到尾节点。 (1).head (2).head.next (3).head.next.next (n).head.next.n.n
public void display(){
Node<E> temp = this.head;
//从头节点开始遍历到为尾节点
while(temp != null){
System.out.println(temp.getData());
temp = temp.next; //指向下一节点。
}
} //返回链表list
public List<Node<E>> findAll(){
List<Node<E>> list = new ArrayList<Node<E>>();
Node<E> temp = this.head;
while(temp != null){
list.add(temp);
temp = temp.next;
}
return list;
} //查找指定位置结点
public Node<E> findByIndex(int index){
Node<E> temp = this.head;
int i = 0; //参数校验,返回null
if(index < i || index > this.size){
System.err.println("参数大于链表长度或者小于0:" + index);
return null;
} //如果index == 0,返回头节点
if(index == 0){
return this.head; //如果下标为1,直接返回头节点
} //遍历链表进行匹配
while(temp != null){
if(i == index){
return temp; //匹配节点
}
temp = temp.next; //继续遍历
i ++;
}
return null;
} //获得链表节点数量
public int getSize(){
return this.size;
} //获取当前头节点
public Node<E> getHead(){
return this.head;
} //测试我的链表
public static void main(String[] args) {
LinkedList<Integer> linkedList = new LinkedList<Integer>(); //添加节点
linkedList.addNode(1);
linkedList.addNode(2);
linkedList.addNode(3);
linkedList.addNode(4);
linkedList.addNode(5);
linkedList.addNode(6); linkedList.insert(6, 9);
linkedList.updateByIndex(6, 9);
linkedList.display(); } }

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

  1. 数据结构——单链表java简易实现

    巩固数据结构 单链表java实现 单链表除了表尾 每个几点都有一个后继 结点有数据和后继指针组成  通过构建表头和表尾(尾部追加需要)两个特殊几点 实现单链表的一些操作,代码如下 package co ...

  2. 数组和链表--Java学习笔记(一)

    版权声明: 本文由Faye_Zuo发布于http://www.cnblogs.com/zuofeiyi/, 本文可以被全部的转载或者部分使用,但请注明出处. 我是一个全职妈妈,两年前在上海一家人力资源 ...

  3. leecode 归并排序 链表(java)

    写了好久,终于写成了.第一次zai leecode错题,题目质量很高,适合面试,与 1.归并排序是稳定的,在java中 Arrays.sort(a);中对于对象的排序就是归并排序.对于原子类型数据使用 ...

  4. 单链表---java实现

    单链表优点:1.不需要预先给出元素个数. 2.单链表插入删除时不需要移动数据元素. 单链表缺点:1.每个节点有指针,空间利用率低. 2.单链表不支持随机读取数据. Node.java package ...

  5. java数据结构之链表(java核心卷Ⅰ读书笔记)

    1.链表 数组和ArrayList的一个重大缺陷就是:从中间位置删除一个元素要付出很大的代价,因为在这个元素删除之后,所有的元素都要向前端移动,在中间的某个位置插入一个元素也是这个原因. (小感悟:s ...

  6. LeetCode--021--合并两个有序链表(java)

    将两个有序链表合并为一个新的有序链表并返回.新链表是通过拼接给定的两个链表的所有节点组成的. 示例: 输入:1->2->4, 1->3->4 输出:1->1->2- ...

  7. 单链表Java实现

    近期在复习基本数据结构,本文是单链表的Java实现,包含对单链表的实现插入删除查找遍历等.最后还实现了单链表的逆置. 实现了多项式相加,多项式相乘. 原文章及完整源码在这里 http://binhua ...

  8. 剑指offer面试题5:逆序打印单链表(Java)

    Java创建单链表(头插法.尾插法),并逆序打印单链表: package day_0324; import java.util.Scanner; import java.util.Stack; cla ...

  9. 对象数组、集合、链表(java基础知识十五)

    1.对象数组的概述和使用 * 需求:我有5个学生,请把这个5个学生的信息存储到数组中,并遍历数组,获取得到每一个学生信息. Student[] arr = new Student[5]; //存储学生 ...

随机推荐

  1. 使用web api开发微信公众号,调用图灵机器人接口(二)

    此文将分两篇讲解,主要分为以下几步 签名校验; 首次提交验证申请; 接收消息; 被动响应消息(返回XML); 映射图灵消息及微信消息; 此篇为第二篇. 被动响应消息(返回XML) 上一篇中,我们已经可 ...

  2. $('#uplodFileForm')[0].submit();

    jquery对象在[0]以下是取其相对应的Dom对象,即$("#mainForm")[0] = document.getElementById("mainForm&quo ...

  3. 一个针对string的较好的散列算发djb2

    var djb2HashCode = function(key) { var hash = 5831; for(var i = 0; i < key.length; i++) { hash = ...

  4. C#平均值计算器具体实现

    1. 题目及要求 2. Avg.cs 在直接编写窗口程序之前,我们需要创建一个Avg类,我们可以在类库中编辑,也可以像java一样直接在项目中新建类. 有关类库的创建与连接方法,我们在上一次的< ...

  5. 《数据结构与算法图解》 分享 pdf下载

    链接:https://pan.baidu.com/s/1gOMlwU5ucHYDVazvVMk2uw提取码:bk5x

  6. linux文件种类及其扩展名

    文件种类 普通文件(ls -al出来第一列为-) 纯文本文件(ASCII):linux系统中最多的一种文件类型,可以使用cat直接读取: 二进制文件(binary):linux下面的可执行文件: 数据 ...

  7. CS224n学习笔记1——深度自然语言处理

    一.什么是自然语言处理呢? 自然语言处理是计算机科学家提出的名字,本质上与计算机语言学是同义的,它跨越了计算机学.语言学以及人工智能学科. 自然语言处理是人工智能的一个分支,在计算机研究领域中,也有其 ...

  8. dvwa学习笔记之xss

    反射型Low 直接输入<script>alert(/xss/)</script>就可以发现弹窗Medium 检查源码 可以看到网站对输入字符进行了过滤,尝试双写绕过,构造< ...

  9. 编写和调试Android下JNI程序流程

    1,切换到Android目录下bin/classes,使用javah命令生成jni所需的头文件,命令类似于:javah com.xxx.ooo,其中,com.xxx为package名称,ooo为包含n ...

  10. Daily Scrum (2015/10/23)

    这天晚上PM和我一起细算下来这周的确做了不少事儿.由于这天是周五,有的组员今晚有外出活动,有的组员忙了一周想休息一下.所以PM与我讨论提出今晚就布置些阅读的任务,给组员们一些自由分配的时间: 成员 今 ...