1、创建链结构实体Node

/**
* 链表结构实体类
*/
public class Node {
Node next = null; //下一节点
int data; //节点数据 public Node(int data) {
this.data = data;
}
}

2、链表的操作(链表的头结点创建、增加元素,删除元素、求链表长度、根据输入数据求下标)

/**
* 链表功能实现
*/
public class Linked_List { Node head = null; //链表头结点 /**
* 1、求链表长度:以备后续用
* 思路:遍历一个节点,记录长度加一(注意:初始长度给0)
*
* @return int:返回长度
*/
public int get_length() {
int list_length = ;
Node cur_node;
cur_node = head;
while (cur_node != null) {
list_length++;
cur_node = cur_node.next;
}
return list_length;
} /**
* 2、添加
* 思路:找到链表的末尾节点,把新的数据节点添加在后面
*
* @param date :插入的数据
*/
public void add_Node(int date) {
Node newnode = new Node(date);
if (head == null) { //判断是否只有一个头结点
head = newnode;
return;
} else {
Node temp = head;
while (temp.next != null) { //不为头节点,找到最后一个节点
temp = temp.next;
}
temp.next = newnode;
}
} /**
* 3、删除
* 思路:传入下标,根据下标,找到相应的节点,删除节点的前一节点指向删除节点下一节点
*
* @param index:删除的数据的下标
* @return
*/
public boolean delete_Node(int index) {
if (index < || index > get_length()) {
System.out.println("你所要删除的元素下标输入有问题");
return false;
}
if (index == ) {
head = head.next;
return true;
}
Node pre_node = head;
Node cur_node = pre_node.next;
int i = ;
while (pre_node != null) {
if (i == index) {
pre_node.next = cur_node.next;
return true;
} else {
pre_node = pre_node.next;
cur_node = cur_node.next;
i++;
}
}
return true;
} /**
* 4、根据输入数据求下标
* @param data:输入的数据
* @return int:返回输入数据下标
*/
public int get_data(int data) {
Node node = head;
int index = ;
while (node != null){
if (node.data == data){
return index;
}
node = node.next;
index++;
}
return -;
}
/**
* 5、打印显示输出
*/
public void print_linklist() {
Node node = head;
while (node != null) {
System.out.print(node.data + " ");
node = node.next;
}
System.out.println();
} public static void main(String[] args) { //1、创建链表
Linked_List linked_list = new Linked_List();
//2、添加链表元素
linked_list.add_Node();
linked_list.add_Node();
linked_list.add_Node();
linked_list.add_Node();
//3、打印添加的元素
linked_list.print_linklist();
//4、删除下标元素
linked_list.delete_Node();
linked_list.print_linklist(); //5、获取链表长度
System.out.println("链表长度 "+ linked_list.get_length()); int index = linked_list.get_data(); if (index == -){
System.out.println("你要查找的数据不存在");
}else{
System.out.println("你要查找的数据元素下标 " + index);
}
}
}

3、实现结果小测试


链表长度 3     (1被删除,长度减一)
你要查找的数据不存在 (由于1已被删除,所有在main中求1的下标不在)

1、单链表的实现(java代码)的更多相关文章

  1. 理解单链表的反转(java实现)

    要求很简单,输入一个链表,反转链表后,输出新链表的表头.   反转链表是有2种方法(递归法,遍历法)实现的,面试官最爱考察的算法无非是斐波那契数列和单链表反转,递归方法实现链表反转比较优雅,但是对于不 ...

  2. 数据结构(一) 单链表的实现-JAVA

    数据结构还是很重要的,就算不是那种很牛逼的,但起码得知道基础的东西,这一系列就算是复习一下以前学过的数据结构和填补自己在这一块的知识的空缺.加油.珍惜校园中自由学习的时光.按照链表.栈.队列.排序.数 ...

  3. 数据结构之单链表的实现-java

    一.单链表基本概念 单链表是一种链式存取的数据结构,用一组地址任意的存储单元(一般是非连续存储单元)存放线性表中的数据元素.链表中的数据是以结点来表示的,每个结点的构成:元素data + 指针next ...

  4. 数据结构(2):单链表学习使用java实现

    单链表是单向链表,它指向一个位置: 单链表常用使用场景:根据序号排序,然后存储起来. 代码Demo: package com.Exercise.DataStructure_Algorithm.Sing ...

  5. 数据结构之单链表(基于Java实现)

    链表:在计算机中用一组任意的存储单元存储线性表的数据元素称为链式存储结构,这组存储结构可以是连续的,也可以是不连续的,因此在存储数据元素时可以动态分配内存. 注:在java中没有指针的概念,可以理解为 ...

  6. [算法] 单链表插入排序(java)

    实现 首先保证插入前的链表是个完整的,最后一个节点要断开 然后在插入前链表中找到比待插入节点大的最小元素,插到前面即可 Link.java class Link { private class Nod ...

  7. 二叉树(二叉链表实现)JAVA代码

      publicclassTest{       publicstaticvoid main(String[] args){           char[] ch =newchar[]{'A','B ...

  8. 【线性表基础】顺序表和单链表的插入、删除等基本操作【Java版】

    本文表述了线性表及其基本操作的代码[Java实现] 参考书籍 :<数据结构 --Java语言描述>/刘小晶 ,杜选主编 线性表需要的基本功能有:动态地增长或收缩:对线性表的任何数据元素进行 ...

  9. java 单链表反转

    最近与人瞎聊,聊到各大厂的面试题,其中有一个就是用java实现单链表反转.闲来无事,决定就这个问题进行一番尝试. 1.准备链表 准备一个由DataNode组成的单向链表,DataNode如下: pub ...

  10. C代码实现非循环单链表

    C代码实现非循环单链表, 直接上代码. # include <stdio.h> # include <stdlib.h> # include <malloc.h> ...

随机推荐

  1. 面试java后端面经_3

    小姐姐说:你一点都不懂表达,一点都不懂爱情,一点也不爱我! 你答:你知道吗,我听说过一个这样的故事,讲的就是有一个小女孩和一个男孩在一起,小男孩呢很不幸是位聋哑人,虽然如此,但是他们的日子过得特别的美 ...

  2. 章节十六、1-TestNG简介

    一.TestNG 介绍 1.TestNG 是一个来自 JUnit 和 NUnit 的测试框架,它具拥有更多的功能,提高了 执行的效率. 2.TestNG 是一个开源的自动化测试框架 去除了老框架的大部 ...

  3. github的详细使用,非常简单!

    https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/

  4. C语言编程入门之--第五章C语言基本运算和表达式-part3

    5.3  挑几个运算符来讲 常用的运算符除了加减乘除(+-*/)外,还有如下: 注意:以下运算符之间用逗号隔开,C语言中也有逗号运算符,这里不讲逗号运算符. 1. 赋值运算符 =,+=,*= 2. 一 ...

  5. SpringBoot中快速实现邮箱发送

    前言 在许多企业级项目中,需要用到邮件发送的功能,如: 注册用户时需要邮箱发送验证 用户生日时发送邮件通知祝贺 发送邮件给用户等 创建工程导入依赖 <!-- 邮箱发送依赖 --> < ...

  6. iNeuOS 物联网云操作系统2.0发布,集成设备容器、视图建模、机器学习三大模块

    目       录 1.      概述... 2 2.      使命及目标... 3 3.      系统框架... 4 4.      设备容器(iNeuKernel)... 4 5.      ...

  7. jvm系列(七):如何优化Java GC「译」

    本文由CrowHawk翻译,地址:如何优化Java GC「译」,是Java GC调优的经典佳作. Sangmin Lee发表在Cubrid上的”Become a Java GC Expert”系列文章 ...

  8. Codeforces 1004E

    题意略. 思路: 这k个点应该放在这棵树的直径上,并且能连成一条路径.如果k比树的直径上的点要多,那么我们就不用把这k个点都用上, 只需要把这棵树直径上所有的点都覆盖上就行了.如果k比树的直径上的点要 ...

  9. JavaScript 数据结构与算法之美 - 你可能真的不懂递归

    1. 前言 算法为王. 排序算法博大精深,前辈们用了数年甚至一辈子的心血研究出来的算法,更值得我们学习与推敲. 因为之后要讲有内容和算法,其代码的实现都要用到递归,所以,搞懂递归非常重要. 2. 定义 ...

  10. Eureka(一)术语详解(用具体的事物理解抽象的概念)

    最近工作较闲,所以自己研究了下eureka的原理,实现,和集群搭建等.(注:我没实操过eureka集群项目,都是自己做的demo产生的结论,如果有错误欢迎指出) 首先说一下我对eureka的一些术语的 ...