1.详细解释单链表中的头结点;2.Java算法——力扣707题:设计链表

news/2024/7/24 10:04:17 标签: 算法, java, leetcode

1.详细解释单链表中的头结点

在做这道算法之前,首先务必要弄明白三个问题:
对于含头节点的单链表,

  1. 头结点是否是第一个节点?
  2. 单链表的长度是否包含该头节点?
  3. 头结点是否有索引?如果有的话,又是多少?

对于这个问题,AI给出的答案是:

对于含头节点的单链表,
1.头结点不是第一个节点,头结点的作用是为单链表增加一个虚拟节点,方便对链表的操作。
2.单链表的长度不包括头节点,并且头节点在遍历时不被计算。
3.头节点没有索引,其作用只是作为单链表的一个哨兵节点,用于帮助程序员更好地操作单链表。例如当链表为空时,头结点的下一个指针将为空,这时就可以根据头结点是否为空来判断链表是否为空,从而减少一些判断操作。

这三个问题对于学习过数据结构的人来说,应该是很基础的。但作为上学期刚学完数据结构,并且自认为学得还可以的本大二学生来说,因为没弄清楚头节点,导致在这道算法上花了很多时间,所以今天特地开个贴来记录一下。

2. 算法: 设计链表

2.1 题目

好了,接下来先看题:
在这里插入图片描述
tips:
在这里插入图片描述
楼主这里选择使用的是单链表,所以双链表就不看了。

2.2 自定义的链表(ListNode)

java">public class ListNode {
    public int val; //数据域
    public ListNode next; //指针域,指向下一个节点

    public ListNode() {
    }

    public ListNode(int val) {
        this.val = val;
    }

    public ListNode(int val, ListNode next) {
        this.val = val;
        this.next = next;
    }
}

2.3 算法实现

java">class MyLinkedList {
    int size; //链表元素个数
    ListNode head; //头结点

    public MyLinkedList() {
        this.size = 0;
        this.head = new ListNode(0);
    }

    // 1.获取下标为index的节点的值
    public int get(int index) {
        if (index < 0 || index > size - 1) {
            return -1;
        }

        ListNode cur = head; //设置cur指针指向头节点
        for (int i = 0; i <= index; i++) {
            cur = cur.next;
        }
        return cur.val;
    }

    // 2.在头节点 和 下标为0的节点(链表的第一个节点)之间插入一个节点
    public void addAtHead(int val) {
        addAtIndex(0, val);
    }

    // 3.在链表的末尾插入一个节点
    public void addAtTail(int val) {
        addAtIndex(size, val);
    }

    // 4.在下标为index的节点前插入一个节点
    public void addAtIndex(int index, int val) {
        if (index > size) { //index比链表长度大,不插入
            return;
        }

        ListNode cur = head; //设置cur指针指向头节点

        // 让cur.next 指向下标为index的节点
        for (int i = 0; i < index; i++) {
            cur = cur.next;
        }
        ListNode newNode = new ListNode(val, cur.next);
        cur.next = newNode;
        size++; //表长+1
    }

    // 5.删除下标为index的节点
    public void deleteAtIndex(int index) {
        if (index < 0 || index >= size) {
            return;
        }

        ListNode cur = head; //设置cur指针指向头节点

        // 让cur.next 指向下标为index的节点
        for (int i = 0; i < index; i++) {
            cur = cur.next;
        }
        cur.next = cur.next.next;
        size--; //表长-1
    }
}

http://www.niftyadmin.cn/n/5436263.html

相关文章

springBoot项目,无配置中心,怎么实现类似功能

实现EnvironmentPostProcessor import cn.hutool.http.HttpUtil; import org.springframework.boot.SpringApplication; import org.springframework.boot.env.EnvironmentPostProcessor; import org.springframework.boot.env.YamlPropertySourceLoader; import org.springfr…

Rocky Linux - Primavera P6 EPPM 安装及分享

引言 继上一期发布的Redhat Linux版环境发布之后&#xff0c;近日我又制作了基于Rocky Enterprise Linux 的P6虚拟机环境&#xff0c;同样里面包含了全套P6 最新版应用服务 此虚拟机仅用于演示、培训和测试目的。如您在生产环境中使用此虚拟机&#xff0c;请先与Oracle Primav…

第四章 Java 网络编程

一、OSI 七层模型和 TCP/IP 四层模型 1、OSI&#xff08;Open System Interconnect&#xff09;&#xff0c;即开放式系统互联。 一般都叫 OSI 参考模型&#xff0c;是 ISO&#xff08;国际标准化组织&#xff09;组织在 1985 年研究的网络互联模型。 2、TCP/IP 协议栈是美国国…

我手写的轮子开源了

我手写的轮子开源了 文章目录 1.gitee坐标和地址1.1.gitee坐标1.2.gitee地址 2.github坐标和地址2.1.github坐标2.2.github地址 3.总结 1.gitee坐标和地址 1.1.gitee坐标 <dependency><groupId>io.gitee.bigbigfeifei</groupId><artifactId>es-sprin…

人工智能入门之旅:从基础知识到实战应用(二)

一、人工智能必备基础知识 1. 数学基础 线性代数、概率统计和微积分等数学学科在人工智能&#xff08;AI&#xff09;中起着至关重要的作用&#xff0c;并在各种应用场景中发挥着关键作用&#xff1a; 线性代数&#xff08;Linear Algebra&#xff09;&#xff1a; 在人工智能…

python--剑指offer--15. 二进制中1的个数

编写一个函数&#xff0c;输入是一个无符号整数&#xff08;以二进制串的形式&#xff09;&#xff0c;返回其二进制表达式中数字位数为 ‘1’ 的个数&#xff08;也被称为 汉明重量).&#xff09;。 提示&#xff1a; 请注意&#xff0c;在某些语言&#xff08;如 Java&…

后端工程师快速使用axios

文章目录 01.AJAX 概念和 axios 使用模板目标讲解代码解析案例前端后端结果截图 02.URL 查询参数模板目标讲解案例前端后端结果截图 03.常用请求方法和数据提交模板目标讲解案例前端后端结果截图 04.axios 错误处理模板目标讲解案例前端后端结果截图 01.AJAX 概念和 axios 使用…

AI检测识别技术,为智能化视频生产赋能

在科技飞速发展的今天&#xff0c;智能化生产已经成为企业提高效率、降低成本、增强竞争力的关键所在。美摄科技&#xff0c;作为一家在音视频处理技术领域保持领先的创新型企业&#xff0c;不仅致力于提供卓越的音视频处理技术&#xff0c;更在AI检测识别领域积累了深厚的实力…