当前位置: 首页 > news >正文

《数据结构之美--链表oj练习》

链表oj题分享

1. 移除链表元素

题目:

在这里插入图片描述

思路分析:

根据题目描述,可以看出该题是要将满足条件的链表元素删除,并且返回新的头结点. 首先我们想到的肯定是直接遍历该链表然后对满足条件的元素进行删除,但删除某个元素时还会影响前后节点,因此还需要修改前后元素的指针,但显然这样就显得很麻烦,我们不妨换一种角度来看这个问题,既然题目要求我们删除满足条件的元素,也就是保留不满足条件的元素,为此,我们是不是可以搞一个新的链表,然后从前往后遍历原链表,只要是不满足条件的元素就尾插到新链表之后,这样就避免了一些不方便的操作,为此给出实现方案。

代码实现:

在这里插入图片描述
我们根据思路一气呵成写出了上面的代码,乍一看是没什么问题,但提交之后就会发现出错了。

在这里插入图片描述

这里我们可以看出这个测试用例是要求我们把val值为6的节点删除,但我们还是输出了最后一个满足条件的节点,咦?这是为什么呢?我们再仔细地检查一遍代码,就不难发现在处理到倒数第二个节点时,让newtail指针指向了该节点,然后最后一个节点满足删除条件,因此我们没有将其插入到新链表中,接着就返回了新的头结点,但是我们忽略了一个细节,newtail指针的next指针并未置为空,它还是指向最后一个节点,但是最后一个节点我们是不要的啊,因此,只需要在返回头结点之前,将newtailnext指针置为空即可

在这里插入图片描述
可以看到,在特判尾节点之后我们这道题就AC了

题目传送门 :

203–移除链表元素: link

2. 反转链表

题目:

在这里插入图片描述

思路分析:

这道题要求很简单,就是将链表反转一下,然后返回新的头结点,因此我们很容易想出一种思路:就是创建一个新链表(脑海中),然后从前往后遍历原链表,不断进行头插操作。
这里我再来提供另一种思路 : 定义三个指针 n1 n2 n3n1 置为空,n2 指向头结点
n3 指向头结点的下一个节点,然后n2不为空的情况下不断更新三个指针的值,让n2 的next指针 指向 n1n1 指向 n2n2 指向 n3 ,只要n3 不为空就往后走,跳出循环时n1 就指向原链表的最后一个节点。
下面画图来分析这种方法

画图分析

在这里插入图片描述

代码实现:

方法一:

在这里插入图片描述
这里的思路虽然简单,但是需要注意的一点就是你在修改指针的时候会修改pcurnext指针,但之后你还要走到下一个节点的位置,但是此时next指针已经被修改了,因此在修改指针之前需要定义一个中间指针来暂存next指针。

方法二:

在这里插入图片描述
这里需要注意的一个细节就是n3指针在往后走的时候要注意判断是否为空,以防对空指针的解引用.

题目传送门

206-反转链表:链接: link

3. 链表的中间节点

题目 :

在这里插入图片描述

思路分析 :

通过阅读题目,这道题目就是要求我们返回一个链表中的中间节点,因此我们脑海中很快就产生了一个思路,如果我们知道链表中节点的个数,然后直接返回中间的节点不就可以了,这个思路也容易实现,只需要将链表遍历一遍就可以统计出链表的节点个数。
这里再分享另一种思路:快慢指针
定义两个指针:slow fast ,一开始都让它们指向头结点,之后遍历链表,slow指针每次走一步,fast指针每次走两步,当fast指针走到尾节点时循环结束,此时slow指针指向的就是中间节点。

画图分析

在这里插入图片描述

代码实现:

方法一:

在这里插入图片描述

方法二:

在这里插入图片描述
这里唯一需要的就是while循环中的两个条件不能交换位置,因为有可能会出现对空指针的解引用,这时就会报错。

题目传送门:

876-链表的中间节点-: link

4. 合并有序链表

题目:

在这里插入图片描述

思路分析:

读完题目,可以发现这道题目就是要让我们把两个链表按升序合并,这里注意很重要的一个点(两个有序序列),其实这道题和之前我们做过的合并两个有序数组很相似,这也是归并排序的一个核心思想,因此我们只需用合并两个有序数组的逻辑来实现就行,(定义两个指针遍历两个链表,每次将较小的节点尾插到新链表当中,由于两个链表肯定会有一个先遍历完,接着只需将剩下的链表挂到新链表之后即可,因为两个链表都是有序的)。

代码实现:

初始代码:

typedef struct ListNode ListNode;
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) {
//特判空链表情况
if(list1 == NULL)
{
return list2;
}
if(list2 == NULL)
{
return list1;
}
ListNode* newhead,*newtail;
newhead = newtail = NULL;
ListNode* cur1, *cur2;
cur1 = list1,cur2 = list2;
while(cur1 && cur2)
{
if(cur1->val <= cur2->val)
{
//尾插
if(newhead == NULL)
{
newhead = newtail = cur1;
}
else
{
newtail->next = cur1;
newtail = cur1;
}
cur1 = cur1->next;
}
else
{
//尾插
if(newhead == NULL)
{
newhead = newtail = cur2;
}
else
{
newtail->next = cur2;
newtail = cur2;
}
cur2 = cur2->next;
}
}
//因为肯定会有一个链表先遍历完,接着把没遍历完的那个链表直接挂到尾部即可
if(cur1)
{
newtail->next = cur1;
newtail = newtail->next;
}
if(cur2)
{
newtail->next = cur2;
newtail = newtail->next;
}

return newhead;
}

唯一需要注意的就是链表为空的情况,这时候要判空

虽然这个代码实现很简单,但尾插部分的代码显得太过冗余了,而且我们还需要判断链表是否为空,这样很麻烦,因此这里我们其实可以创建一个带头链表,之后往头结点之后尾插节点,这样就省去了判空的操作,下面给出优化的代码

优化代码:

typedef struct ListNode ListNode;
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) {
//特判空链表情况
if(list1 == NULL)
{
return list2;
}
if(list2 == NULL)
{
return list1;
}
ListNode* p = (ListNode*)malloc(sizeof(ListNode));
ListNode* newhead,*newtail;
newhead = newtail = p;
ListNode* cur1, *cur2;
cur1 = list1,cur2 = list2;
while(cur1 && cur2)
{
if(cur1->val <= cur2->val)
{
newtail->next = cur1;
newtail = cur1;
cur1 = cur1->next;
}
else
{
newtail->next = cur2;
newtail = cur2;
cur2 = cur2->next;
}
}
//因为肯定会有一个链表先遍历完,接着把没遍历完的那个链表直接挂到尾部即可
if(cur1)
{
newtail->next = cur1;
newtail = newtail->next;
}
if(cur2)
{
newtail->next = cur2;
newtail = newtail->next;
}
return newhead->next;
}

这里需要注意两个点:

  1. 我们返回的头结点是newhead ->next ,因为头结点使我们自己申请的
  2. 由于我们申请了一个节点,在最后的时候需要释放掉。

题目传送门

21-合并两个有序链表-: link

5. 链表回文

题目:

在这里插入图片描述

思路分析:

思路一

根据之前解决回文数和回文字符串的经验来解决这道题。
将链表的所有节点存入一个数组中,然后定义一前一后两个指针,不断地比较两个位置的节点是否相同。

思路二

先找到链表的中间节点,将中间节点作为新链表的头结点进行反转,然后定义两个指针,一个从原链表的头结点开始,另一个指针从原链表的尾节点开始,不断比较节点是否相同

画图分析

在这里插入图片描述

代码实现:

方法一:

在这里插入图片描述

方法二:

在这里插入图片描述
这里注意我们在判断是否回文的时候,while循环中的条件是以右边指针不为空。

题目传送门:

234-回文链表-: link

6. 相交链表

题目:

在这里插入图片描述

思路分析:

读完题目,可以知道题目是要求我们判断两个链表是否相交,判断两个链表是否相交,其实就是判断两个链表是否存在相同的地址,那我们不是定义两个指针来同时遍历两个链表,然后每走一步就判断两个节点是否相同不就可以了吗?但我们拿示例来模拟得话就会发现,当两个链表长度不相等时就会出错。因此我们就需要固定两个指针的出发点,让较长的那个链表的指针先走几步,之后就可以正确地来判断了。

代码实现:

在这里插入图片描述

题目传送门:

160-相交链表-: link

7. 环形链表

题目:

在这里插入图片描述

思路分析:

通过题目描述,我们知道这道题目就是要求我们来判断一个链表是否有环,乍一看没什么思路,其实这道题也可以用到之前的快慢指针,如果链表带环的话,那么快慢指针一定会相遇,否则说明链表不带环。

画图分析:

在这里插入图片描述

代码实现:

在这里插入图片描述

题目传送门:

141-环形链表-: link

8. 环形链表||

题目:

在这里插入图片描述

思路分析:

这道题相比上道题单纯地判断链表是否带环,只是多了一个如果带环的话要求我们返回入环的起始节点,上道题我们是通过快慢指针来判断是否带环,如果带环的话快慢指针一定会相遇,也就是说我们可以找到快慢指针相遇的节点,那么我们知道这个有什么用呢? 其实这里存在着一个很重要的性质:相遇点到入环起始点的距离与头结点到入环起始节点的距离是相等的
既然存在这个性质,我们就可以在找到快慢指针相遇点之后,定义两个指针,一个从头结点开始,一个从相遇点开始,同时进行遍历,这两个指针的相遇点就是我们要找的入环起始点。
讲到这里可能会有同学怀疑这个性质的正确性,下面我们来证明一下:

证明:

在这里插入图片描述

代码实现:

在这里插入图片描述

题目传送门:

142-环形链表||-: link

总结:

这篇文章主要是和大家分享一些简单的单链表oj题来巩固一下学习的单链表,上面几道题如果有更优的算法欢迎随时和我交流分享。

相关文章:

《数据结构之美--链表oj练习》

链表oj题分享 1. 移除链表元素 题目&#xff1a; 思路分析&#xff1a; 根据题目描述&#xff0c;可以看出该题是要将满足条件的链表元素删除&#xff0c;并且返回新的头结点. 首先我们想到的肯定是直接遍历该链表然后对满足条件的元素进行删除&#xff0c;但删除某个元素时…...

杂记-LeetCode中部分题思路详解与笔记-HOT100篇-其四

那今天我们就把Hot100的所有题都完结了吧&#xff0c;Hot100作为大多数人笔试题的入门之选&#xff0c;可以说是非常的经典了&#xff0c;但是俗话说得好&#xff0c;书读百遍&#xff0c;其意自现&#xff0c;我不支持反复地只刷部分算法题&#xff0c;但是我支持周期性地刷刷…...

SpringBoot私人西服系统开发与设计

概述 基于SpringBoot的私人西服系统项目&#xff0c;是一个实用的服装管理系统。该系统包含了西服选择、面料选择、预约管理等核心功能。 主要内容 1. 管理员功能模块 用户管理&#xff1a;管理注册用户信息服装款式管理&#xff1a;管理西服款式信息面料类别管理&#xff…...

2.2/Q2,Charls最新文章解读

文章题目&#xff1a;Association of uric acid to high-density lipoprotein cholesterol ratio with the presence or absence of hypertensive kidney function: results from the China Health and Retirement Longitudinal Study (CHARLS) DOI&#xff1a;10.1186/s12882-…...

云端免费训练 AI 大模型推荐(适用于个人学习)

学习 AI 大模型训练&#xff08;如LLM、扩散模型等&#xff09;&#xff0c;云端服务器是必不可少的&#xff0c;因为大模型对算力&#xff08;GPU/TPU&#xff09;和内存要求极高。以下是 适合不同学习阶段 的云端服务器推荐&#xff0c;涵盖 免费、低成本、高性能 选项&#…...

《操作系统真象还原》第九章(2)——线程

《操作系统真象还原》第九章&#xff08;2&#xff09;——线程 文章目录 《操作系统真象还原》第九章&#xff08;2&#xff09;——线程前言多线程调度简单优先级调度的基础任务调度器和任务切换注册时钟中断处理函数实现调度器schedule实现任务切换函数switch_to启用线程调度…...

Windows程序包管理器WinGet实战

概述 WinGet&#xff0c;Windows Package Manager&#xff0c;Windows软件包管理器&#xff0c;开源在GitHub&#xff0c;GitHub Releases可下载&#xff0c;官方文档。 WinGet由一个命令行工具和一组用于在Windows 10/11等版本上安装应用的服务组成&#xff0c;可帮助用户快…...

【特殊场景应对1】视觉设计:信息密度与美学的博弈——让简历在HR视网膜上蹦迪的科学指南

写在最前 作为一个中古程序猿,我有很多自己想做的事情,比如埋头苦干手搓一个低代码数据库设计平台(目前只针对写java的朋友),比如很喜欢帮身边的朋友看看简历,讲讲面试技巧,毕竟工作这么多年,也做到过高管,有很多面人经历,意见还算有用,大家基本都能拿到想要的offe…...

番外篇 | SEAM-YOLO:引入SEAM系列注意力机制,提升遮挡小目标的检测性能

前言:Hello大家好,我是小哥谈。SEAM(Squeeze-and-Excitation Attention Module)系列注意力机制是一种高效的特征增强方法,特别适合处理遮挡和小目标检测问题。该机制通过建模通道间关系来自适应地重新校准通道特征响应。在遮挡小目标检测中的应用优势包括:1)通道注意力增强…...

Top100(26-30)

二叉树的中序遍历 给定一个二叉树的根节点 root &#xff0c;返回 它的 中序 遍历 。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[1,3,2] 示例 2&#xff1a; 输入&#xff1a;root [] 输出&#xff1a;[] 示例 3&#xff1a; 输入&#x…...

在 Vue 3 中将拆分后的数组合并回原数组

接上文Vue 3 中按照某个字段将数组分成多个数组_vue3怎么进行数组对象--分割对象-CSDN博客 方法一&#xff1a;使用 flat() 方法 // 假设这是拆分后的多维数组 const splitArrays [[{id: 1, category: A}, {id: 3, category: A}],[{id: 2, category: B}, {id: 5, category: …...

MyBatis如何配置数据库连接并实现交互?

如果你用过MyBatis&#xff0c;肯定知道它的核心功能之一就是数据库连接管理。但很多新手在第一次配置时总会遇到各种问题&#xff1a;数据源怎么配&#xff1f;连接池参数如何调优&#xff1f;XML和注解方式有什么区别&#xff1f;今天我们就来彻底搞懂MyBatis连接数据库的每一…...

PyTorch入门------卷积神经网络

前言 参考&#xff1a;神经网络 — PyTorch Tutorials 2.6.0cu124 文档 - PyTorch 深度学习库 一个典型的神经网络训练过程如下&#xff1a; 定义一个包含可学习参数&#xff08;或权重&#xff09;的神经网络 遍历输入数据集 将输入通过神经网络处理 计算损失&#xff08;即…...

Qt官方案例知识点总结(图形视图——Colliding Mice)

Colliding Mice 案例 图元可重写下面的方法&#xff0c;返回一个QPainterPath(形状)&#xff0c;该形状基于图形项自己的坐标系 返回的形状用于碰撞检测、命中测试等&#xff0c;形状越精确&#xff0c;那么碰撞检测等就越准确 不重写的话&#xff0c;默认取 boundingRect()…...

人工智能在后端开发中的革命:从架构到运维

后端开发作为应用程序的"大脑",正在经历人工智能带来的深刻变革。从智能API设计到自动化数据库优化,从异常预测到资源调度,AI技术正在重塑后端开发的各个方面。本文将全面探讨AI如何赋能现代后端系统开发,并通过实际案例展示这些技术的应用价值。 一、智能API开…...

电子电器架构 --- EOL 工厂刷写(产线)

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 周末洗了一个澡,换了一身衣服,出了门却不知道去哪儿,不知道去找谁,漫无目的走着,大概这就是成年人最深的孤独吧! 旧人不知我近况,新人不知我过…...

AI数据分析与BI可视化结合:解锁企业决策新境界

大家好&#xff0c;今天我们来聊聊一个前沿而热门的话题——AI数据分析与BI可视化结合&#xff0c;如何携手推动企业决策迈向新高度。在数据爆炸的时代&#xff0c;企业如何高效利用这些数据&#xff0c;成为制胜的关键。AI数据分析与BI可视化的结合&#xff0c;正是解锁这一潜…...

深度学习3.2 线性回归的从零开始实现

3.2.1 生成数据集 %matplotlib inline import random import torch from d2l import torch as d2ldef synthetic_data(w, b, num_examples):# 生成特征矩阵X&#xff0c;形状为(num_examples, len(w))&#xff0c;符合标准正态分布X torch.normal(0, 1, (num_examples, len(w…...

ArcPy工具箱制作(下)

在上一篇博客中&#xff0c;我们已经初步了解了如何制作ArcPy工具箱&#xff0c;包括工具箱的基本概念、准备工作、脚本编写以及将脚本转换为工具箱的步骤。今天&#xff0c;我们将继续深入探讨ArcPy工具箱的制作&#xff0c;重点介绍一些进阶技巧和优化方法. 一、优化工具箱的…...

if/switch语句初始化功能

基础介绍 这个特性是在c17版本引入的&#xff0c;在这之前是不允许在if语句或者switch语句中使用赋值语句&#xff0c;不仅仅是if语句和switch语句&#xff0c;包括lambda表达式在c17版本也支持类在捕获表达式中支持赋值操作。言归正传&#xff0c;下面阐述这个特性的基本语法…...

cmake 语法大纲

1&#xff0c;基础语法 CMakeLists.txt 目录组织文件&#xff1b; *.cmake 脚本文件 运行: $ cmake -P xxx.cmake *.cmake 模块文件 include 命令来引用 模块文件。 自定义模块&#xff1b; cmake 预制模块&#xff1b; 单行注释 # com 括号注释 #…...

前端单元测试实战:如何开始?

实战&#xff1a;如何开始单元测试 1.安装依赖 npm install --save-dev jest2.简单的例子 首先&#xff0c;创建一个 sum.js 文件 ./sum.js function sum(a, b) {return a b; }module.exports sum;创建一个名为 sum.test.js 的文件&#xff0c;这个文件包含了实际测试内…...

《软件设计师》复习笔记(12.2)——成本管理、配置管理

目录 一、项目成本管理 1. 定义 2. 主要过程 3. 成本类型 4. 其他概念 真题示例&#xff1a; 二、软件配置管理 1. 定义 2. 主要活动 3. 配置项 4. 基线&#xff08;Baseline&#xff09; 5. 配置库类型 真题示例&#xff1a; 一、项目成本管理 1. 定义 在批准…...

edge browser for linux debian

下载地址 https://www.microsoft.com/en-us/edge/download?formMA13FJ 安装 # 下载安装包 wget https://packages.microsoft.com/repos/edge/pool/main/m/microsoft-edge-stable/microsoft-edge-stable_135.0.3179.85-1_amd64.deb?brandM102 # 安装 sudo dpkg -i microsoft…...

Python读取Excel表格数据并写成JSON格式文件(精简版)

&#x1f91f;致敬读者 &#x1f7e9;感谢阅读&#x1f7e6;笑口常开&#x1f7ea;生日快乐⬛早点睡觉 &#x1f4d8;博主相关 &#x1f7e7;博主信息&#x1f7e8;博客首页&#x1f7eb;专栏推荐&#x1f7e5;活动信息 文章目录 1. 步骤步骤 1: 安装必要的库步骤 2: 读取Ex…...

服务器的算力已经被被人占用了,我如何能“无缝衔接”?

今天遇到一个问题&#xff0c;服务器已经被别人占用了&#xff0c;我又不知道什么时候他能结束&#xff0c;因此很难去训练自己的模型&#xff0c;隔一会去看看别人是否结束又太麻烦&#xff0c;于是便可以写这个脚本文件来自动检测服务器是否空闲&#xff0c;一有空闲就可以自…...

rulego-server是一个开源程序,是一个轻量级、无依赖性的工作流自动化平台。支持 iPaaS、流式计算和 AI 能力。

一、软件介绍 文末提供程序和源码下载学习 RuleGo-Server 是一个基于 RuleGo 构建的轻量级、高性能、模块化和集成友好的自动化工作流程平台。可用于自动化编排、iPaaS&#xff08;集成平台即服务&#xff09;、API 编排、应用编排、AI 编排、数据处理、IoT 规则引擎、AI 助手…...

『前端样式分享』联系我们卡片式布局 自适应屏幕 hover动效 在wikijs中使用 (代码拿来即用)

目录 预览效果分析要点响应式网格布局卡片样式&#xff1a;阴影和过渡效果 代码优化希望 长短不一的邮箱地址在左右居中的同时,做到左侧文字对齐(wikijs可用)总结 欢迎关注 『前端布局样式』 专栏&#xff0c;持续更新中 欢迎关注 『前端布局样式』 专栏&#xff0c;持续更新中…...

航电系统之通信技术篇

航电系统&#xff08;航空电子系统&#xff09;的通信技术是现代航空器的核心技术之一&#xff0c;其核心目标是实现飞行器内部各系统之间以及飞行器与外部设备&#xff08;如地面控制中心、其他飞行器等&#xff09;之间高效、可靠的信息交互。随着航空技术的不断发展&#xf…...

4.3 熟悉字符串处理函数

作为一名C语言初学者&#xff0c;掌握字符串处理函数是编程道路上不可或缺的一步。字符串是C语言中处理文本数据的基础&#xff0c;而标准库提供了一系列强大的字符串处理函数&#xff0c;极大地方便了我们的开发工作。本文将带领大家熟悉这些常用的字符串处理函数&#xff0c;…...

二叉树理论基础

二叉树种类 满二叉树&#xff1a;每个非叶子节点都有且只有两个子节点。 和完全二叉树&#xff1a;除了最底层外&#xff0c;其他各层都是满的&#xff1b;最底层的节点都集中在左侧。 二叉搜索树&#xff1a;对于任意节点 u&#xff0c;左子树上所有节 点的值都小于 u.val…...

yarn的三个资源调度策略

### YARN 的三种资源调度策略及其工作原理与区别 #### 1. **FIFO Scheduler (先进先出调度器)** FIFO Scheduler 是一种最简单的调度方式&#xff0c;所有的应用程序都按顺序排队等待执行。其基本逻辑如下&#xff1a; - 应用程序按照提交的时间先后顺序依次进入队列。 - 当集…...

leetcode0112. 路径总和-easy

1 题目&#xff1a;路径总和 官方标定难度&#xff1a;易 给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径&#xff0c;这条路径上所有节点值相加等于目标和 targetSum 。如果存在&#xff0c;返回 true &#xff1…...

铁氧体和纳米晶:车载定制电感的材料选择

最近有个做车载产品的粉丝问到&#xff1a;我们的定制电感产品既会用到铁氧体磁芯&#xff0c;也会用到纳米晶磁芯&#xff0c;那么这两种材料&#xff0c;该如何选择呢&#xff1f; 要回答这个问题&#xff0c;我们首先要对两种材料做一个基本的对比。 铁氧体材料成本低&…...

MCP认证难题破解

一、MCP 认证体系现状与核心挑战 微软认证专家(MCP)体系在 2020 年后逐步向基于角色的认证转型,例如 Azure 管理员(AZ-104)、数据分析师(DP-100)等,传统 MCP 考试已被取代。当前备考的核心难题集中在以下方面: 1. 技术栈快速迭代 云原生技术占比提升:Azure 认证中,…...

ROS机器人一般用哪些传感器?

以下是ROS机器人常用传感器的分层详解及思维导图总结,涵盖传感器分类、核心参数、ROS支持及典型应用: 一、环境感知传感器 1. 视觉传感器 类型 原理 ROS支持 数据类型 典型型号/驱动 优缺点及应用场景 单目摄像头 单镜头成像,通过透视变换获取2D图像,依赖算法推断深度 驱…...

【ubuntu】在Linux Yocto的基础上去适配Ubuntu的wifi模块

一、修改wifi的节点名 1.找到wifi模块的PID和VID ifconfig查看wifi模块网络节点的名字&#xff0c;发现是wlx44876393bb3a&#xff08;wlxmac地址&#xff09; 通过udevadm info -a /sys/class/net/wlx44876393bba路径的命令去查看wlx44876393bba的总线号&#xff0c;端口号…...

基于WebRTC技术的EasyRTC:支持任意平台设备的实时音视频通信解决方案

一、技术架构与核心优势 EasyRTC是一套基于WebRTC技术的实时音视频通信框架&#xff0c;旨在为开发者提供高效、稳定、跨平台的通信解决方案。其核心优势在于支持任意平台设备&#xff0c;包括Web端、移动端、桌面端和嵌入式设备&#xff0c;真正实现“一次开发&#xff0c;多…...

51单片机实验四:键盘检测原理及应用实现

目录 一、实验环境与实验器材 二、实验内容及实验步骤 1.独立键盘检测 2.独立键盘(简易版本&#xff09; 3&#xff0e;矩阵键盘检测 4.矩阵键盘&#xff08;简单版&#xff0c;单数码管&#xff09;&#xff1a; 一、实验环境与实验器材 环境&#xff1a;Keli&#xff0c…...

GN ninja 工程化构建例程

文章目录 1. 前言✨2. 工程实例🚩2.1 工程目录结构2.2 工程顶层.gn文件2.3 工具链配置.gn文件2.4 编译配置.gn文件2.5 编译目标配置.gn文件2.6 工程接口文件2.7 动态库编译.gn文件2.8 动态库源文件2.9 静态库编译.gn文件2.10 静态库源文件2.11 主程序编译.gn文件2.12 主程序源…...

STC定时器频率占空比程序

// // 一、宏定义区 // #include <STC15.H> //头文件 #include <intrins.h> //库函数文件 #define FOSC 12000000L //IRC频率 typedef …...

观察者 ➜ 事件总线:一路走来的碎碎念

写给未来的自己:每次手敲事件模型都要 Google,干脆把思路和踩坑一次性记清楚。文章很长,都是唠叨,目的是让自己看两眼就能把设计理由找回来。 目录 为什么我要折腾事件模型?V0 ─ 单一事件的观察者模式V1 ─ 多事件同步总线(类型拆分)V2 ─ 订阅者优先级(链式调用可控)…...

AOP基本概念

上述语句解释感觉太过玄妙不似常人能够听懂&#xff0c;所以结合自己理解&#xff0c;给自己留点备注&#xff1a; 首先 目标对象&#xff1a; 就是这要对哪个对象进行代理&#xff0c;因为AOP是面向切面编程&#xff0c;在OOP的基础上再次解耦合&#xff0c;这个过程需要提…...

不确定与非单调推理的概率方法

前文我们学习了“不确定与非单调推理的基本概念”,了解了不确定性推理是人工智能领域中处理不完整、不精确或模糊信息的推理方法,其核心是在前提条件或推理规则存在不确定性时,通过某种数学或逻辑机制推导出合理结论,并对结论的可靠性进行量化。不确定与非单调推理的基本概…...

device_fingerprint、device_id、hmac生成

文章目录 1. 写在前面2. 设备信息3. 数美指纹 【&#x1f3e0;作者主页】&#xff1a;吴秋霖 【&#x1f4bc;作者介绍】&#xff1a;擅长爬虫与JS加密逆向分析&#xff01;Python领域优质创作者、CSDN博客专家、阿里云博客专家、华为云享专家。一路走来长期坚守并致力于Python…...

centos下openjdk报:getVersion(FontConfiguration.java)异常,安装fontconfig无效问题的处理

TOC centos下openjdk报:getVersion(FontConfiguration.java)异常,安装fontconfig无效问题的处理 官网jdk包&#xff1a;Releases dragonwell-project/dragonwell8 背景&#xff1a; 为了适应国产化&#xff0c;使用东方通和国产jdk&#xff0c;从tomcat改为tongweb&#x…...

Banana Pi BPI-RV2 RISC-V 路由器开发板发售, 全球首款RISC-V路由器

Banana Pi BPI-RV2 开源路由器是矽昌通信和⾹蕉派开源社区&#xff08;Banana Pi &#xff09;合作设计, 联合打造全球首款RISC-V架构路由器开发板。 这是香蕉派开源社区与矽昌通信继BPI-Wifi5 低成本Wifi5 路由器合作之后的又一力作&#xff0c;为全球开发者与商业客户提供基于…...

自学新标日第十九课复习版本

第十九课 基本–》否定 うー&#xff1e;わ 单词 单词假名声调词义品物しなもの0物品&#xff0c;商品お皿おさら0盘子ごみごみ2垃圾初心者しょしんしゃ2初学者上級者じょうきゅうしゃ3熟练者高級こうきゅう0高级上級クラス5高级版英会話えいかいわ3英语会话コース1路线&a…...

网安加·百家讲坛 | 刘志诚:AI安全风险与未来展望

作者简介&#xff1a;刘志诚&#xff0c;乐信集团信息安全中心总监、OWASP广东区域负责人、网安加社区特聘专家。专注于企业数字化过程中网络空间安全风险治理&#xff0c;对大数据、人工智能、区块链等新技术在金融风险治理领域的应用&#xff0c;以及新技术带来的技术风险治理…...

2025年03月中国电子学会青少年软件编程(Python)等级考试试卷(二级)真题

青少年软件编程&#xff08;Python&#xff09;等级考试试卷&#xff08;二级&#xff09; 分数&#xff1a;100 题数&#xff1a;37 答案解析&#xff1a;https://blog.csdn.net/qq_33897084/article/details/147340870 一、单选题(共25题&#xff0c;共50分) 1. 老师要求大…...