学习数据节构和算法的第13天

单链表

​ 单链表是一种常见的数据结构,由一个个节点组成。

每个节点包含两个部分:数据部分指针部分。

**数据部分:**存储节点中的具体数据。可以是任何类型的数据,如整数、浮点数、字符串等。

**指针部分:**指向下一个节点的地址。通过指针,将多个节点连接在一起形成链表。

链表的第一个节点称为头节点最后一个节点的指针为空指针(NULL或None)表示链表的结束

链表的优点是插入和删除操作的时间复杂度为O(1),不需要像数组一样移动元素。缺点是访问元素时需要遍历整个链表,时间复杂度为O(n)。

class Node:def __init__(self, data):self.data = dataself.next = None
# 创建节点
node1 = Node(1)
node2 = Node(2)
node3 = Node(3)
# 构建链表关系
node1.next = node2
node2.next = node3

链表的移除

#include <stdio.h>
#include <stdlib.h>
// 定义链表节点结构体
typedef struct Node{int data;              // 节点数据struct Node* next;     // 指向下一个节点的指针
} Node;
// 初始化链表节点
Node* initNode(int data){Node* newNode = (Node*)malloc(sizeof(Node));    // 分配新节点的内存newNode->data = data;newNode->next = NULL;return newNode;
}
// 移除指定数值的节点
Node* removeElements(Node* head, int val){Node* dummy = initNode(-1);    // 设置一个虚拟头节点,方便处理删除头节点的情况dummy->next = head;            // 将虚拟头节点指向原链表的头节点Node* current = dummy;         // 当前节点指针while (current->next) {if (current->next->data == val){Node* temp = current->next;current->next = current->next->next;free(temp);             // 释放目标节点的内存} else {current = current->next;}}return dummy->next;             // 返回排除目标节点后的链表头节点
}
// 显示链表元素
void display(Node* head){Node* current = head;while (current) {printf("%d -> ", current->data);current = current->next;}printf("NULL\n");
}
int main() 
{// 创建链表: 1 -> 2 -> 3 -> 4 -> 5 -> NULLNode* head = initNode(1);head->next = initNode(2);head->next->next = initNode(3);head->next->next->next = initNode(4);head->next->next->next->next = initNode(5);printf("Original linked list: ");display(head);    // 显示原链表// 移除数值为3的节点head = removeElements(head, 3);printf("After removing elements: ");display(head);    // 显示移除元素后的链表return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/698013.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

FFMPEG 推流至 NGINX-RTMP 服务

NGINX 是一个非常出色的 HTTP 服务器&#xff0c;FFMPEG 是非常好的音视频框架。通过 NGINX 的 nginx-rtmp-module 模块结合在一起&#xff0c;实现一个流媒体服务器&#xff0c;它支持 RTMP 和 HLS&#xff08;Live Http Stream&#xff09;。 一、FFMPEG 文件推流&#xff1a…

精通Django模板(模板语法、继承、融合与Jinja2语法的应用指南)

模板&#xff1a; 基础知识&#xff1a; ​ 在Django框架中&#xff0c;模板是可以帮助开发者快速⽣成呈现给⽤户⻚⾯的⼯具模板的设计⽅式实现了我们MVT中VT的解耦(M: Model, V:View, T:Template)&#xff0c;VT有着N:M的关系&#xff0c;⼀个V可以调⽤任意T&#xff0c;⼀个…

百度地图海量点方案趟坑记录(百度地图GL版 + MapVGL + vue3 + ts)

核心需求描述 不同层级有不同的海量图标展示底层海量图标需要展示文字拖动、放大缩小都需要重新请求数据并展示固定地图中心点&#xff08;拖动、放大缩小&#xff0c;中心点始终在地图中心&#xff09; 示例图片&#xff1a;&#xff08;某些图片涉及公司数据&#xff0c;就未…

基础数据结构和算法《》

递归 1.递归应该一种比较常见的实现一些特殊代码逻辑时需要做的&#xff0c;但常常也是最绕的一种方式&#xff0c;在解释递归 之前&#xff0c;我们用循环和递归来做个比较1.1.如果你打开一扇门后&#xff0c;同样发现前方也有一扇们&#xff0c;紧接着你又打开下一扇门...直…

备战蓝桥杯---基础算法刷题1

最近在忙学校官网上的题&#xff0c;就借此记录分享一下有价值的题&#xff1a; 1.注意枚举角度 如果我们就对于不同的k常规的枚举&#xff0c;复杂度直接炸了。 于是我们考虑换一个角度&#xff0c;我们不妨从1开始枚举因子&#xff0c;我们记录下他的倍数的个数sum个&#…

Android platform tool中d8.bat不生效

d8.bat因找不到java_exe文件&#xff0c;触发EOF d8.bat中之前代码为&#xff1a; set java_exe if exist "%~dp0..\tools\lib\find_java.bat" call "%~dp0..\tools\lib\find_java.bat" if exist "%~dp0..\..\tools\lib\find_java.bat" …

分享一个我爱工具网源码优化版

应用介绍 本文来自&#xff1a;分享一个我爱工具网源码优化版 - 源码1688 前几天在网上看到了一个不错的工具网源码&#xff0c;但是源码存在一些问题&#xff0c;遂进行了修改优化。 主要修改内容有&#xff1a; 1、后台改为账号密码登录&#xff0c;上传即用&#xff0c;不…

前后端延迟怎么解决

当今互联网应用的发展越来越迅猛&#xff0c;用户对于网站或应用的性能要求也越来越高。其中一个重要方面就是前后端延迟的解决&#xff0c;也就是减少前端与后端之间的通信时间延迟&#xff0c;提高用户体验。本文将详细介绍如何解决前后端延迟的问题。 网络延迟 数据在网络…

【DAY03 软考中级备考笔记】存储系统,总线系统,输入输出系统和可靠性

存储系统&#xff0c;总线系统&#xff0c;输入输出系统和可靠性 2月22日 – 天气&#xff1a;阴转晴 济南下大雪&#xff0c;居家办公两天。 1. 计算机存储器的分类 根据存储位置划分&#xff1a; 内存/主存&#xff1a;用来保存当前正在运行的程序所需要的数据&#xff0c…

【C++精简版回顾】6.构造函数

一。类的四种初始化方式 1.不使用构造函数初始化类 使用函数引用来初始化类 class MM { public:string& getname() {return name;}int& getage() {return age;}void print() {cout << "name: " << name << endl << "age: &quo…

能力组队 | 求最多可以派出多少支团队(C 语言)

题目 用数组代表每个人的能力&#xff0c;一个比赛活动要求&#xff0c;参赛团队的最低能力值为N&#xff0c;每个团队可以由一人或者两人组成&#xff0c;且一个人只能参加一个团队&#xff0c;计算出最多可以派出多少只符合要求的队伍。 输入 第一行代表总人数&#xff0c…

React学习——快速上手

文章目录 初步模块思维 初步 https://php.cn/faq/400956.html 1、可以手动使用npm来安装各种插件&#xff0c;来从头到尾自己搭建环境。 如&#xff1a; npm install react react-dom --save npm install babel babel-loader babel-core babel-preset-es2015 babel-preset-rea…

SQL语法法则

概念 SQL语法规则&#xff1a;SQL是一种结构化编程语言 基础SQL指令通常是以行为单位 SQL指令需要语句结束待&#xff0c;默认是英文分号:;、\g、\G SQL指令类似自然语言 编写的SQL中如果用到了关键字或者保留字&#xff0c;需要使用反引号、来包裹&#xff0c;让系统忽略 …

3.测试教程 - 基础篇

文章目录 软件测试的生命周期软件测试&软件开发生命周期如何描述一个bug如何定义bug的级别bug的生命周期如何开始第一次测试测试的执行和BUG管理产生争执怎么办&#xff08;处理人际关系&#xff09; 大家好&#xff0c;我是晓星航。今天为大家带来的是 测试基础 相关的讲解…

防火墙内容安全笔记

目录 DFI和DPI IDS和IPS 签名 AV URL过滤 HTTPS过滤 内容过滤 文件类型过滤 文件内容过滤 邮件过滤 VPN概述 密码学概述 对称加密 非对称加密 DFI和DPI DFI和DPI技术 --- 深度检测技术 DPI DPI --- 深度包检测技术 --- 主要针对完整的数据包&#xff08;数据包…

【7】测试数据的读写(ARM服务器)

上一章节简单说了下测试项的编写,这一节,我们深入说一下如何编写测试项程序以及测试数据的读写,接下来一起来看一下。 一.环境配置 1.python 3.7.8 可直接进入官网下载安装:Download Python | Python.org 我们还是使用python来进行测试项程序的开发。 2.所需要的库如下…

【springBoot】springAOP

AOP的概述 AOP是面向切面编程。切面就是指某一类特定的问题&#xff0c;所以AOP也可以理解为面向特定方法编程。AOP是一种思想&#xff0c;拦截器&#xff0c;统一数据返回和统一异常处理是AOP思想的一种实现。简单来说&#xff1a;AOP是一种思想&#xff0c;对某一类事务的集…

目标追踪(tracking)简介之核心组成部分及其挑战

目标追踪&#xff08;tracking&#xff09;在技术领域通常指的是使用各种传感器和算法来监测和定位物体在空间中的位置和运动。这一过程广泛应用于多个领域&#xff0c;包括视频监控、机器人导航、自动驾驶汽车、无人机飞行控制、体育分析、以及增强现实和虚拟现实系统中。 目…

Camtasia2024官方标准版重磅发布更新及新版本功能介绍

Camtasia 2024标准版是一款功能强大的屏幕录制和视频编辑软件。它继承了Camtasia系列一贯的易用性和丰富功能&#xff0c;为用户提供了高效、专业的视频制作体验。 在屏幕录制方面&#xff0c;Camtasia 2024标准版支持录制电脑屏幕上的任何内容&#xff0c;包括网站、软件、视…

9、内网安全-横向移动Exchange服务有账户CVE漏洞无账户口令爆破

用途&#xff1a;个人学习笔记&#xff0c;有所借鉴&#xff0c;欢迎指正&#xff01; 背景&#xff1a; 在内网环境的主机中&#xff0c;大部分部署有Exchange邮件服务&#xff0c;对于Exchange服务的漏洞也是频出&#xff0c;在这种情况下&#xff0c;如果拿到内网中一台主机…