如何学linkedList算法
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章将为大家详细讲解有关如何学linkedList算法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。简介linkedList应该是一种非常非常简单
千家信息网最后更新 2025年02月03日如何学linkedList算法
这篇文章将为大家详细讲解有关如何学linkedList算法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
简介
linkedList应该是一种非常非常简单的数据结构了。节点一个一个的连接起来,就成了linkedList。今天我们使用动画的方法一起来看看linkedList是怎么插入和删除的。
linkedList的构建
linkedList是由一个一个的节点构成的。而每个节点只需要存储要保存的数据和下一个节点的引用即可。
linkedList本身需要一个head节点,所以我们的linkedList可以这样构建:
public class LinkedList { Node head; // head 节点 //Node表示的是Linked list中的节点,包含一个data数据和下一个节点的引用 class Node { int data; Node next; //Node的构造函数 Node(int d) { data = d; } }}
linkedList的操作
先看一下linkedList怎么插入数据,插入数据有三种方式,头部插入,尾部插入,中间插入。
头部插入
先看一个头部插入的例子:
头部插入的逻辑是什么呢?
新插入的节点作为head节点,然后将原来的head节点指向当前head节点的next引用即可。
//插入到linkedList的头部 public void push(int newData) { //构建要插入的节点 Node newNode = new Node(newData); //新节点的next指向现在的head节点 newNode.next = head; //现有的head节点指向新的节点 head = newNode; }
尾部插入
再看一下尾部插入的例子:
插入的逻辑是什么呢?
找到最后一个节点,然后将最后一个节点的next指向新插入的节点。
//新节点插入到list最后面 public void append(int newData) { //创建新节点 Node newNode = new Node(newData); //如果list是空,则新节点作为head节点 if (head == null) { head = newNode; return; } newNode.next = null; //找到最后一个节点 Node last = head; while (last.next != null) { last = last.next; } //插入 last.next = newNode; return; }
中间插入
再看一下中间插入的例子:
这个例子中,我们在第三个节点的位置插入了一个93。
插入逻辑就是先找到第二个节点,将第二个节点的next指向新节点,然后将新节点的next指向原先的第三个节点。
看下java代码如何实现:
//插入在第几个元素之后 public void insertAfter(int index, int newData) { Node prevNode = head; for (int i = 1; i < index; i++) { if (prevNode == null) { System.out.println("输入的index有误,请重新输入"); return; } prevNode = prevNode.next; } //创建新的节点 Node newNode = new Node(newData); //新节点的next指向prevNode的下一个节点 newNode.next = prevNode.next; //将新节点插入在prevNode之后 prevNode.next = newNode; }
删除节点
再看一下怎么删除某个位置的节点:
上面的例子中,我们要删除第5个节点。
删除的逻辑就是找到第4个节点和第6个节点。然后将第四个节点的next指向第6个节点即可。
看下相应的java代码如下:
//删除特定位置的节点 void deleteNode(int index) { // 如果是空的,直接返回 if (head == null) return; // head节点 Node temp = head; // 如果是删除head节点 if (index == 1) { head = temp.next; return; } // 找到要删除节点的前一个节点 for (int i=1; temp!=null && inext 是要删除的节点,删除节点 Node next = temp.next.next; temp.next = next; }
关于如何学linkedList算法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
节点
指向
例子
头部
数据
逻辑
位置
尾部
算法
三个
代码
内容
就是
文章
更多
知识
篇文章
输入
不错
元素
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
设置数据库只保留正数
丰南区信息网络技术答疑解惑
数据库2005还原速度很慢
修改数据库编号字段属性
乌拉服务器是什么游戏
数据库内网传输数据库
dbv导入数据库
珠海网络安全法
软件开发技术分析图配色
定制软件开发系统
数据库dcl
mit数据库
辽宁专业软件开发价格优惠
银行做软件开发怎么样
三分钟教你开一个mc服务器
方舟非官方服务器有mod吗
服务器系统保存路径
服务器关机后风扇还在转动
一个服务器有几个固定ip
阿里云电脑端服务器地址
怎么样学会网络技术
用什么应用软件开发报表
富文本编辑器内容上传到服务器
pci服务器
数据库系统的安全性要求包括
千潮互联网科技
长沙值得去的网络安全公司
条件存在数据库怎么查询
网络安全多久体检一次
博客文章保存数据库