码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据结构——链表


    链表

    这里写目录标题

      • 链表的插入
        • 尾插法
        • 头插法
        • 在指定位置插入
        • 在指定位置删除
      • 链表输出
        • 方法一
        • 方法二
        • 输出链表长度
        • 判断值是否存在于链表
      • 链表相关算法
        • 找中间节点
        • 判断是否成环
        • 判断是否带环并返回第一个相遇点
        • 截取链表后k个节点
      • 单链表反转
        • 头插法反转链表
        • 就地逆置法反转链表(重点)

    链表是链式存储

    image-20220613140306383

    链表的节点有两部分组成:value和next

    image-20220613140334805

    image-20220613140500419

    java如何构建节点呢?

    java的内存分为栈和堆内存

    栈中往往存放变量。堆中往往存放对象

    image-20220613140648880

    每个节点在java中都可以视为一个对象:对象中存在两个全局变量也就是value和next值

    那么对象如何创建呢?

    类是对象的模板

    package com.qcby.datastructure.List;
    
    public class ListNode {
       
        int value;//节点的数据区域
        ListNode next;//记录下一个节点的地址
        //构造器、
        public ListNode(int value) {
       
            this.value = value;
        }
         @Override
        public String toString() {
       
            return "ListNode{" +
                    "value=" + value +
                    ", next=" + next +
                    '}';
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    package com.qcby.datastructure.List;
    
    public class Test {
       
        public static void main(String[] args) {
       
            ListNode node1 = new ListNode(3);
            ListNode node2 = new ListNode(4);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    问题一:next为什么是ListNode类型的数据

    Java是强类型语言。定义什么样的类型就是要在内存中开辟什么样的空间。如int类型就只开辟32bit空间(1符号位31数值位)

    ListNode node1 = new ListNode(3);

    我们直接访问node 的时候,得到的是地址的值。说明node1在堆内存当中存储着ListNode类型对象的地址,而next是存放下一个ListNode类型对象的地址,node1是ListNode类型,那么next也只能是ListNode类型

    链表的插入

    尾插法

    插入的数据是顺序

    package com.qcby.datastructure.List;
    
    public class LinkList {
       
    
        public ListNode head =null;
    
        /**
         * 尾插法
         * @param value,要插入的值
         */
        public void insert(int value){
       
            ListNode listNode =new ListNode(value);
            if (head==null){
       
                head = listNode;
                return;
            }
            ListNode indexNode = head;
            while (indexNode.next !=null){
       
                indexNode = indexNode.next;
            }
            listNode.next=listNode;
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    package com.qcby.datastructure.List;
    
    public class Test {
       
        public static void main(String[] args) {
       
            LinkList linkList =new LinkList
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
  • 相关阅读:
    如何在本地安装多个nodejs版本,方便前端开发
    Linux开发工具VI/VIM
    SpringBoot容器化部署_Dockerfile制作镜像
    openlayers 绘制动态迁徙线、曲线
    6个顶级BI和数据可视化工具
    这应该是java最好用的orm之一了
    工业企业网络推广解决方案 | 网络营销专家分享 | 上海添力
    溅射生长的铜和钨薄膜的应力调整
    提升市场调研和竞品分析效率:利用Appium实现App数据爬取
    1204. 最后一个能进入电梯的人
  • 原文地址:https://blog.csdn.net/m0_61820867/article/details/126548337
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号