Java单链表的增删改查与面试题详解

目录
  • 一、单链表的增删改查
    • 1、创建结点
    • 2、单链表的添加操作
    • 3、单链表的删除操作
    • 4、单链表的有效结点的个数
  • 二、大厂面试题

一、单链表的增删改查

1、创建结点

单链表是由结点连接而成,所以我们首先要创建结点类,用于对结点进行操作。定义data属性 表示序号,定义name属性表示结点存放的数据信息,定义next属性表示指向下一个结点。构造器只需要放入data属性和name属性,重写toString方法方便打印结点信息。

public class Node {
    public int data;
    public String name;
    public Node next;
    public Node(int data, String name){
        this.data = data;
        this.name = name;
    }
    @Override
    public String toString() {
        return "Node{" +
                "data=" + data +
                ", name='" + name + '\'' +
                '}';
    }
}

2、单链表的添加操作

首先创建头结点

此结点表示链表的头,不存放实际数据的。

private Node head = new Node(0,"");

添加操作

将新的结点添加到链表的尾部,我们首先要遍历链表,找到链表的尾部,然后将最后一个结点的next指向新的结点,新结点的next指向NULL,这样就完成了链表的添加操作,这种每次添加到链表的尾部的操作称为尾插法。注意,当我们遍历链表时,需要一个辅助结点temp来进行遍历,因为head头结点不能动。

public class SingleLinkedList {
    //首先创建头结点,此结点表示链表的头,无具体数据
    private Node head = new Node(0,"");
    //添加结点操作
    public void addData(Node node){
        Node temp = head;
        while (true){
            if (temp.next == null){
                temp.next = node;
                node.next = null;
                break;
            }
            temp = temp.next;
        }
    }
}

3、单链表的删除操作

假设我们要删除中间这个结点,我们只需要将这个结点的上一个结点的next指向这个结点的下一个结点(也就是将第一个结点的next指向第三个结点)。

     public void delData(Node node){
        Node temp = head;
        while (true){
            //如果是要删除的结点
            if (temp.next.data == node.data){
                temp.next = temp.next.next;
                break;
            }else if(temp.next == null){
                System.out.println("未找到结点!");
                break;
            }
            temp = temp.next;
        }
    }

4、单链表的有效结点的个数

我们可以定义一个计数的变量count,初始化为0,然后循环遍历链表,每遍历到一个结点,count就加一,这样就能求出单链表的有效个数。

    public int countData(){
        Node temp = head.next;
        int count = 0;
        while (true){
            if (temp == null){
                break;
            }
            count++;
            temp = temp.next;
        }
        return count;
    }

二、大厂面试题

1、新浪微博:查找单链表中倒数第k个结点

从上图可以看出,假设要找倒数第2个结点,我们该怎么做?不难看出,倒数第二个结点也是顺序的第三个结点,也就是将倒数的结点转换成顺序结点,遍历链表找到顺序结点即可。因为是有明确表示是第几个结点,所以我们需要知道结点的有效个数,前面我们介绍了有效个数的求法,直接用即可。当我们要找倒数第k个结点,我们可以转换成顺序的第(count - k + 1)个结点。比如:k = 2,count = 4, 倒数第2个结点也就是顺序第(4 - 2 + 1 = 3)个结点。

    public Node referNode(int n){
        //根据前面计算有效个数的方法,求得链表总结点个数
        int max = countData();
        //计数
        int count = 1;
        //判断指定的结点是否在范围内
        if (!(n >= 1 && n <= max)){
            throw new RuntimeException("没有此结点!");
        }
        //辅助结点
        Node temp = head.next;
        //循环遍历查找
        while (true){
            //满足条件,则是我们要找的结点
            if (count == (max - n + 1)){
                return temp;
            }else {
                temp = temp.next;
                count++;
            }
        }
    }

2、腾讯面试题:单链表的反转

首先创建辅助变量temp用于循环原来的链表,辅助变量temp1记录temp的下一个位置,每遍历到一个结点就插入到新链表的头部,这种方式称为头插法。

public void nodeReversal(Node head){
        //如果链表为空或链表只有一个结点,则不需要反转
        if (head.next == null || head.next.next == null){
            return;
        }
        //辅助变量temp
        Node temp = head.next;
        //辅助变量temp1
        Node temp1 = null;
        //循环遍历
        while (true){
            //退出循环的条件
            if (temp == null){
                break;
            }
            //首先将temp的下一个结点给temp1
            temp1 = temp.next;
            //然后将temp的next指向新链表头headReversal的next(头指向的下一个)
            temp.next = headReversal.next;
            //再然后将新链表头headReversal的next指向temp结点
            headReversal.next = temp;
            //最后将temp1记录的结点赋值给temp
            temp = temp1;
        }
        //遍历结束,将新的顺序替换原来的顺序
        head.next = headReversal.next;
        //显示链表,这个方法需要自己写
        showList(head);
}

到此这篇关于Java单链表的增删改查与面试题详解的文章就介绍到这了,更多相关Java单链表增删改查内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Java如何实现单链表的增删改查

    一.新建学生节点类 Stu_Node节点包含: 学号:int num; 姓名:String name; 性别:String gender; 下一个节点:Stu_Node next; 为了便于打印节点内容需要重写toString方法 class Stu_Node{ int num; String name; String gender; Stu_Node next; @Override public String toString() { return "Stu_Node{" + &qu

  • java实现单链表中的增删改

    本文实例为大家分享了java实现单链表中增删改的具体代码,供大家参考,具体内容如下 什么是链表 链表是有序的列表,但是它在内存中是存储如下 小结: 链表是以节点的方式来存储,是链式存储 每个节点包含data 域, next 域:指向下一个节点. 如图:发现链表的各个节点不一定是连续存储. 链表分带头节点的链表和没有头节点的链表,根据实际的需求来确定 单链表(带头结点) 逻辑结构示意图如下 单链表的增删改应用实例 使用带head 头的单向链表实现——三国英雄排行榜管理完成对英雄人物的增删改查操作

  • Java实现单链表SingleLinkedList增删改查及反转 逆序等

    节点类 可以根据需要,对节点属性进行修改.注意重写toString()方法,以便后续的输出操作. //节点类 class Node { public int id; public String name; public Node next; public Node(int id, String name) { this.id = id; this.name = name; } @Override public String toString() { return "Node{" + &

  • java实现单链表增删改查的实例代码详解

    package 数据结构算法.链表; /* *定义节点 * 链表由节点构成 */ public class Node<E> { private E e; //数据data private Node<E> next; //指向下一个节点 public Node() { } public Node(E e) { this.e = e; } public Node<E> getNext() { return next; } public void setNext(Node&l

  • Java 单链表数据结构的增删改查教程

    我就废话不多说了,大家还是直接看代码吧~ package 链表; /** * *1)单链表的插入.删除.查找操作: * 2)链表中存储的是int类型的数据: **/ public class SinglyLinkedList { private Node head = null; //查找操作 public Node findByValue(int value){ Node p = head; //从链表头部开始查找 while(p.next != null && p.data != va

  • Java单链表的增删改查与面试题详解

    目录 一.单链表的增删改查 1.创建结点 2.单链表的添加操作 3.单链表的删除操作 4.单链表的有效结点的个数 二.大厂面试题 一.单链表的增删改查 1.创建结点 单链表是由结点连接而成,所以我们首先要创建结点类,用于对结点进行操作.定义data属性 表示序号,定义name属性表示结点存放的数据信息,定义next属性表示指向下一个结点.构造器只需要放入data属性和name属性,重写toString方法方便打印结点信息. public class Node { public int data;

  • Mybatis增删改查mapper文件写法详解

      1. 插入 <mapper namespace="需要实现接口的全类名"> <insert id="需要实现的接口里的方法名" parameterType="方法参数类型,如果是对象要写全类名"> INSERT sql命令(命令里通过#{}获取对象属性) <!--注意属性名区分大小写 --> </insert> <mapper> EG: <mapper namespace=&q

  • thinkPHP框架通过Redis实现增删改查操作的方法详解

    本文实例讲述了thinkPHP框架通过Redis实现增删改查操作的方法.分享给大家供大家参考,具体如下: 一.概述 Redis是一个NoSQL数据库,由于其数据类型的差异,所以要在MVC框架中实现CURD操作,比较繁锁.事实上在ThinkPHP框架中,只能实现简单的缓存应用.而不像MongoDB那样能够实现常见数据库的CURD操作.本文章将通过扩展的方式,实现Redis的CURD操作,这样我们就可以像操作普通的Mysql数据库那样实现Redis的编程了. 二.实现过程 接下为将以ThinkPHP

  • Vue项目通过node连接MySQL数据库并实现增删改查操作的过程详解

    目录 Vue项目通过node连接MySQL数据库 1.创建Vue项目 2.下载安装需要的插件 3.在项目中创建server文件夹,用于搭建本地服务器 4.Vue项目访问接口获取数据 数据表的增删改查操作 1.服务器配置 2.前端配置 页面样式 总结 Vue项目通过node连接MySQL数据库 1.创建Vue项目 vue create 项目名 Vue项目创建的详细步骤,有需要的可移步这里 2.下载安装需要的插件 下载express npm install express 下载cors,用于处理接口

  • Android SQLite数据库增删改查操作的使用详解

    一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字). TEXT(字符串文本)和BLOB(二进制对象)数据类型,虽然它支持的类型只有五种,但实际上sqlite3也接受varchar(n). char(n).decimal(p,s) 等数据类型,只不过在运算或保存时会转成对应的五种数据类型. SQLite最大的特点是你可以把各种类型的数据保存到任何字段中,而不用关心字段

  • PHP增删改查项目的实战详解

    sql: -- phpMyAdmin SQL Dump -- version 4.5.1 -- http://www.phpmyadmin.net -- -- Host: 127.0.0.1 -- Generation Time: 2022-03-15 17:51:32 -- 服务器版本: 10.1.13-MariaDB -- PHP Version: 5.6.21 SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO"; SET time_zone = &quo

  • C语言数据结构之单链表与双链表的增删改查操作实现

    目录 前言 单链表的增删改查 定义结构体以及初始化 增加结点 删除结点 查找修改结点 移除结点 最终效果 双链表的基本操作 初始化建表 遍历双链表 指定位置插入结点 指定位置删除结点 查找结点位置 最终效果 结语 前言 上篇博客分享了创建链表传入二级指针的细节,那么今天就分享几个c语言课程实践设计吧.这些程序设计搞懂了的话相当于链表的基础知识牢牢掌握了,那么再应对复杂的链表类的题也就能慢慢钻研了.学习是一个积累的过程,想要游刃有余就得勤学苦练! 单链表的增删改查 (1)项目需求 构造带有头结点的

随机推荐