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

单向循环链表的概念+单向循环链表的结点插入+单向循环链表的结点删除+程序设计与笔试题分析

  1. 单向循环链表的原理与应用

思考:对于单向链表而言,想要遍历链表,则必须从链表的首结点开始进行遍历,请问有没有更简单的方案实现链表中的数据的增删改查?

回答:是有的,可以使用单向循环的链表进行设计,单向循环的链表的使用规则和普通的单向链表没有较大的区别,需要注意:单向循环链表的尾结点的指针域中必须指向链表的首结点的地址,由于带头结点的单向循环链表更加容易进行管理,所以教学以带头结点的为例:

上图所示的就是一个典型的单向循环链表的结构,可以发现单向循环链表的结构属于环形结构,链表中的最后一个结点的指针域中存储的是链表的第一个结点的地址。

为了管理单向循环链表,需要构造头结点的数据类型以及构造有效结点的数据类型,如下:

  1. 创建一个空链表,由于是使用头结点,所以就需要申请头结点的堆内存并初始化即可!

  1. 创建新结点,为新结点申请堆内存并对新结点的数据域和指针域进行初始化,操作如下:

  1. 根据情况把新结点插入到链表中,此时可以分为尾部插入、头部插入、指定位置插入:
  • 头插

  • 尾插

  • 中插

  1. 根据情况可以从链表中删除某结点,此时可以分为尾部删除、头部删除、指定元素删除:
  • 头删

  • 尾删

  • 中删

  1. 双向链表的原理与应用

如果想要提高单向链表或者单向循环链表的访问速度,则可以在链表中的结点中再添加一个指针域,让新添加的指针域指向当前结点的直接前驱的地址,也就意味着一个结点中有两个指针域(prev + next),也被称为双向链表(Double Linked List)。

由于带头结点更加方便用户进行数据访问,所以本次创建一条带头结点的双向不循环的链表。

  1. 创建一个空链表,由于是使用头结点,所以就需要申请头结点的堆内存并初始化即可!

  2. 创建新结点,为新结点申请堆内存并对新结点的数据域和指针域进行初始化,操作如下:

  3. 根据情况可以从链表中插入新结点,此时可以分为尾部插入、头部插入、指定位置插入:
  • 头插

  • 尾插

  • 中插
  • (略)
  1. 根据情况可以从链表中删除某结点,此时可以分为尾部删除、头部删除、指定结点删除:
  • 头删

  • //利用头删法实现结点删除
    bool SencdList_Head_Delete(Node_t *HeadPointer)
    {//备份头结点的地址Node_t *p =HeadPointer;//检查参数有效性if (HeadPointer == NULL){ fprintf(stderr,"SencdList HeadPointer is error,errno = %d,%s\n",errno,strerror(errno));return false;}//检查链表是否为空if (p->Next == NULL){fprintf(stderr,"SencdList is Empty,errno = %d,%s\n",errno,strerror(errno));return false;}//链表不为空,分两种情况,第一种只有一个结点,另一种有多个结点//只有一个结点if (p->Next->Next == NULL){free(p->Next);p->Next = NULL;return true;}//有多个结点else{p->Next = p->Next->Next;        //头结点的next指向新首结点p->Next->perv->Next = NULL;     //原首结点的next指向null//释放要删除的结点空间free(p->Next->perv);//更新新首结点的prevp->Next->perv = NULL;printf("Delete is  OK\n");return true;}}

  • 尾删

  • //利用尾删法删除结点
    bool SencdList_Tail_Delete(Node_t *TailPointer)
    {//备份头结点的地址Node_t *p =TailPointer;//检查参数有效性if (TailPointer == NULL){ fprintf(stderr,"SencdList TailPointer is error,errno = %d,%s\n",errno,strerror(errno));return false;}//检查链表是否为空if (p->Next == NULL){fprintf(stderr,"SencdList TailPointer is Empty,errno = %d,%s\n",errno,strerror(errno));return false;}//如果链表不为空,有两种情况,一种为只有一个结点,另一种有多个结点//只有一个结点if (p->Next->Next == NULL)  //判断首结点的next是否指向null{free(p->Next);              //释放首结点的内存空间p->Next = NULL;             //更新头结点的指针域return true;}//有多个结点else{while (p->Next != NULL){p = p->Next; //p往后移}//循环结束p指向尾结点p->perv->Next = NULL; //新尾结点的next指向nullp->perv = NULL;       //原尾结点的prev指向null//释放尾结点空间free(p);return true;}}

  • 中删
  • (略)

三、双向循环链表的原理与应用

双向循环链表与双向链表的区别:指的是双向循环链表的首结点中的prev指针成员指向链表的尾结点,并且双向循环链表的尾结点里的next指针成员指向链表的首结点,所以双向循环链表也属于环形结构。

由于带头结点更加方便用户进行数据访问,所以本次创建一条带头结点的双向循环的链表。

// 5.结构体、联合体、枚举的定义。
typedef int Data_Type_t;//结构体用来装链表的
typedef struct CirularSencdListNode
{struct CirularSencdListNode    *perv; //链表的perv指针域,指向结点的直接前驱Data_Type_t              Data; //链表的数据域struct CirularSencdListNode    *Next; //链表的next指针域,指向结点的直接后继}Node_t;
  1. 创建一个空链表,由于是使用头结点,所以就需要申请头结点的堆内存并初始化即可!

  2. //创建新的链表(头结点)
    Node_t* CirularSencdList_Create(void)
    {//为链表申请堆空间Node_t *Pragmar = (Node_t*)calloc(1,sizeof(Node_t));//检查参数有效性if (Pragmar == NULL){fprintf(stderr,"CirularSencdList Create is error,errno = %d,%s\n",errno,strerror(errno));exit(-1);}//链表的初始化Pragmar->Next = Pragmar; //记录next指针域Pragmar->perv = Pragmar; //记录prev指针域printf("CirularSencdList Create is OK\n");return Pragmar;}

  1. 创建新结点,为新结点申请堆内存并对新结点的数据域和指针域进行初始化,操作如下:

  2. //创建新的结点
    Node_t* CirularSencdList_NewNode(Data_Type_t Data )
    {//为链表申请堆空间Node_t *NewNode = (Node_t*)calloc(1,sizeof(Node_t));//检查参数有效性if (NewNode == NULL){fprintf(stderr,"CirularSencdList Create is error,errno = %d,%s\n",errno,strerror(errno));exit(-1);}//链表的初始化NewNode->Data = Data; //记录数据域NewNode->Next = NewNode; //记录next指针域NewNode->perv = NewNode; //记录prev指针域printf("NewNode Create is OK\n");return NewNode;}
    

  1. 根据情况可以从链表中插入新结点,此时可以分为尾部插入、头部插入、指定位置插入:
  2. 头插

//头插法为链表插入结点
bool CirularSencdList_HeadInsert(Node_t *HeadPointer,Data_Type_t Data)
{//备份头结点的地址Node_t *p =HeadPointer;Node_t *p_cur =HeadPointer->Next;//检查参数有效性if (HeadPointer == NULL){ fprintf(stderr,"CirularSencdList HeadPointer is error,errno = %d,%s\n",errno,strerror(errno));return false;}//创建新结点并初始化Node_t * NewNode = CirularSencdList_NewNode(Data);//检查链表是否为空if (p->Next == HeadPointer){p->Next = NewNode;printf("insert is ok\n");return true;}//如果链表不为空p->Next->perv->Next = NewNode;  //尾结点的next指向新结点NewNode->perv  = p->Next->perv; //新结点的prev指向尾结点NewNode->Next =p->Next;         //新结点的next指向原首结点p->Next->perv = NewNode;        //原首结点的prev指向新结点p->Next = NewNode;              //更新头结点的指针域return true;}
  1. 尾插

  2. //尾插法为链表插入结点
    bool CirularSencdList_Tail_Insert(Node_t *TailPointer,Data_Type_t Data)
    {//备份头结点的地址Node_t *p =TailPointer;//检查参数有效性if (TailPointer == NULL){ fprintf(stderr,"CirularSencdList TailPointer is error,errno = %d,%s\n",errno,strerror(errno));return false;}//创建新结点并初始化Node_t * NewNode = CirularSencdList_NewNode(Data);//检查链表是否为空if (p->Next == TailPointer){p->Next = NewNode;return true;}//如果链表不为空p->Next->perv->Next = NewNode; //原尾结点的next指向新结点NewNode->perv =p->Next->perv;  //新结点的prev指向原尾结点NewNode->Next = p->Next;       //新结点的next指向首结点p->Next->perv = NewNode;       //首结点的prev指向新结点return true;}

  3. 根据情况可以从链表中删除某结点,此时可以分为尾部删除、头部删除、指定结点删除:
  4. 头删

  5. //利用头删法实现结点删除
    bool CirularSencdList_Head_Delete(Node_t *HeadPointer)
    {//备份头结点的地址Node_t *p =HeadPointer;//检查参数有效性if (HeadPointer == NULL){ fprintf(stderr,"CirularSencdList HeadPointer is error,errno = %d,%s\n",errno,strerror(errno));return false;}//检查链表是否为空if (p->Next == HeadPointer){fprintf(stderr,"CirularSencdList is Empty,errno = %d,%s\n",errno,strerror(errno));return false;}//链表不为空有两种情况,一种为只有一个结点,另一种有多个结点//只有一个结点if (p->Next->Next == p->Next)  //判断首结点的next是否指向首结点本身{p->Next->Next = NULL;     //首结点的next指向nullp->Next->perv = NULL;     //首结点的prev指向nullfree(p->Next);            //释放首结点p->Next = HeadPointer;    //更新头结点的指针域return true;}else{p->Next = p->Next->Next;             //更新头结点的指针域p->Next->perv = p->Next->perv->perv; //新首结点的prev指向尾结点p->Next->perv->Next->Next = NULL;    //原首结点的next指向nullp->Next->perv->Next->perv = NULL;    //原首结点的prev指向null//释放原首结点的内存空间free(p->Next->perv->Next);p->Next->perv->Next = p->Next;       //尾结点的next指向新首结点}printf("Delete is  OK\n");return true;}

    尾删

  6. //利用尾删法删除结点
    bool CirularSencdList_Tail_Delete(Node_t *TailPointer)
    {//备份头结点的地址Node_t *p =TailPointer;//检查参数有效性if (TailPointer == NULL){ fprintf(stderr,"CirularSencdList TailPointer is error,errno = %d,%s\n",errno,strerror(errno));return false;}//检查链表是否为空if (p->Next == TailPointer){fprintf(stderr,"CirularSencdList TailPointer is Empty,errno = %d,%s\n",errno,strerror(errno));return false;}//如果链表不为空,有两种情况,第一种是只有一个结点,另一种是有多个结点//只有一个结点if (p->Next->Next == p->Next)  //判断首结点的next是否指向自身{p->Next->Next = NULL;      //首结点的next指向nullp->Next->perv = NULL;      //首结点的prev指向null//释放首结点的内存空间free(p->Next); //更新头结点的指针域            p->Next = TailPointer;return true;}//有多个结点    p->Next->perv =p->Next->perv->perv;p->Next->perv->Next->Next = NULL;p->Next->perv->Next->perv = NULL;//释放尾结点空间free(p->Next->perv->Next);p->Next->perv->Next = p->Next;return true;}

练习:

练习:

练习:

练习:

练习:

练习:

练习:

相关文章:

单向循环链表的概念+单向循环链表的结点插入+单向循环链表的结点删除+程序设计与笔试题分析

单向循环链表的原理与应用 思考:对于单向链表而言,想要遍历链表,则必须从链表的首结点开始进行遍历,请问有没有更简单的方案实现链表中的数据的增删改查? 回答:是有的,可以使用单向循环的链表…...

【蓝桥杯嵌入式入门与进阶】2.与开发板之间破冰:初始开发板和原理图2

个人主页:Icomi 专栏地址:蓝桥杯嵌入式组入门与进阶 大家好,我是一颗米,本篇专栏旨在帮助大家从0开始入门蓝桥杯并且进阶,若对本系列文章感兴趣,欢迎订阅我的专栏,我将持续更新,祝你…...

Jetson Xavier NX 安装 CUDA 支持的 PyTorch 指南

本指南将帮助开发者完成在 Jetson Xavier NX 上安装 CUDA 支持的 PyTorch。 安装方法 在 Jetson 上安装 Pytorch 只有两种方法。 一种是直接安装他人已经编译好的 PyTorch 轮子;一种是自己从头开始开始构建 PyTorch 轮子并且安装。 使用轮子安装 可以从我的 Gi…...

“harmony”整合不同平台的单细胞数据之旅

其实在Seurat v3官方网站的Vignettes中就曾见过该算法,但并没有太多关注,直到看了北大张泽民团队在2019年10月31日发表于Cell的《Landscap and Dynamics of Single Immune Cells in Hepatocellular Carcinoma》,为了同时整合两类数据&#xf…...

[权限提升] 操作系统权限介绍

关注这个专栏的其他相关笔记:[内网安全] 内网渗透 - 学习手册-CSDN博客 权限提升简称提权,顾名思义就是提升自己在目标系统中的权限。现在的操作系统都是多用户操作系统,用户之间都有权限控制,我们通过 Web 漏洞拿到的 Web 进程的…...

大模型本地部署流程介绍

大模型本地部署流程介绍 随着人工智能技术的快速发展,大模型(如大型语言模型、图像识别模型等)的应用越来越广泛。然而,由于这些模型通常体积庞大且计算资源要求高,如何在本地环境中高效部署成为了一个重要的议题。以…...

浅析百度AOI数据与高德AOI数据的差异性

目录 前言 一、AOI属性数据 1、百度AOI数据 2、高德AOI数据 二、AOI矢量边界 1、百度AOI空间范围 2、高德AOI空间范围 三、数据获取频次和难易程度 1、接口限制 2、数据转换成本 四、总结 前言 在当今数字化时代,地理信息数据的精准性和丰富性对于城市规划…...

LeetCode 119. 杨辉三角 II

题意:求杨辉三角(帕斯卡三角)的第n行(n从0开始) 杨辉三角的每一行是二项式排列组合的展开式 第n行为: C n 0 , C n 1 , C n 2 , … , C n n C_{n}^{0}, C_{n}^{1}, C_{n}^{2}, \dots, C_{n}^{n} Cn0​,Cn1​,Cn2​,……...

机器学习-K近邻算法

文章目录 一. 数据集介绍Iris plants dataset 二. 代码三. k值的选择 一. 数据集介绍 鸢尾花数据集 鸢尾花Iris Dataset数据集是机器学习领域经典数据集,鸢尾花数据集包含了150条鸢尾花信息,每50条取自三个鸢尾花中之一:Versicolour、Setosa…...

设计模式Python版 原型模式

文章目录 前言一、原型模式二、原型模式示例三、原型管理器 前言 GOF设计模式分三大类: 创建型模式:关注对象的创建过程,包括单例模式、简单工厂模式、工厂方法模式、抽象工厂模式、原型模式和建造者模式。结构型模式:关注类和对…...

centos安装mysql

下面的方法不行,最后还是通过我自己的博客中的 https://blog.csdn.net/qq_21237549/article/details/133759503 CentOS 安装MySQL 详细教程 安装成功的 通过网盘分享的文件:服务器部署 链接: https://pan.baidu.com/s/12QwjIMgwHcwVeVoal-BKrg 提取码:…...

java 判断Date是上午还是下午

我要用Java生成表格统计信息,如下图所示: 所以就诞生了本文的内容。 在 Java 里,判断 Date 对象代表的时间是上午还是下午有多种方式,下面为你详细介绍不同的实现方法。 方式一:使用 java.util.Calendar Calendar 类…...

Jenkins安装部署(以及常见报错解决方案),jdk版本控制器sdkman

目录 零、环境介绍 一、Jenkins安装 1、插件安装以及更换插件源 2、修改jenkins时区 二、sdkman安装(可选) 1、sdkman常用方法 2、sdkman常用方法演示 2.1、查看可用的jdk 2.2、下载jdk并切换版本 三、jenkins报错解决 1、下载sdkman后systemc…...

【Linux】gdb——Linux调试器

gdb使用背景 程序的发布方式有两种,debug模式和release模式 Linux gcc/g出来的二进制程序,默认是release模式 要使用gdb调试,必须在源代码生成二进制程序的时候, 加上 -g 选项 gdb使用方法 首先进入gdb gdb test_glist显示代码 断点 b 行…...

978.最长湍流子数组

目录 题目过程解法收获 题目 给定一个整数数组 arr ,返回 arr 的 最大湍流子数组的长度 。 如果比较符号在子数组中的每个相邻元素对之间翻转,则该子数组是 湍流子数组 。 更正式地来说,当 arr 的子数组 A[i], A[i1], …, A[j] 满足仅满足…...

LLM - 大模型 ScallingLaws 的指导模型设计与实验环境(PLM) 教程(4)

欢迎关注我的CSDN:https://spike.blog.csdn.net/ 本文地址:https://spike.blog.csdn.net/article/details/145323420 免责声明:本文来源于个人知识与公开资料,仅用于学术交流,欢迎讨论,不支持转载。 Scaling Laws (缩放法则) 是大模型领域中,用于描述 模型性能(Loss) 与…...

【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.19 排序革命:argsort的十大高阶用法

1.19 排序革命:argsort的十大高阶用法 目录 #mermaid-svg-Qu8PcmLkIc1pOQJ7 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-Qu8PcmLkIc1pOQJ7 .error-icon{fill:#552222;}#mermaid-svg-Qu8PcmLkIc1pOQJ…...

记忆力训练day07

逻辑分类联想记忆法 一 课程目标 (1)掌握如何分类信息 (2)掌握如何运用逻辑分类方法进行记忆 小试牛刀: 核心的内容: 文字逻辑分类记忆:把文字分类后转换成画面连接记忆。 玫瑰 大树 太阳…...

RK3588平台开发系列讲解(ARM篇)ARM64底层中断处理

文章目录 一、异常级别二、异常分类2.1、同步异常2.2、异步异常三、中断向量表沉淀、分享、成长,让自己和他人都能有所收获!😄 一、异常级别 ARM64处理器确实定义了4个异常级别(Exception Levels, EL),分别是EL0到EL3。这些级别用于管理处理器的特权级别和权限,级别越高…...

算法1-1 模拟与高精度

目录 一 阶乘数码 二 麦森数 三 模拟题 一 阶乘数码 本题中n<1000,1000的阶乘为以下这么大&#xff0c;远超long的范围 402387260077093773543702433923003985719374864210714632543799910429938512398629020592044208486969404800479988610197196058631666872994808558901…...

(四)线程 和 进程 及相关知识点

目录 一、线程和进程 &#xff08;1&#xff09;进程 &#xff08;2&#xff09;线程 &#xff08;3&#xff09;区别 二、串行、并发、并行 &#xff08;1&#xff09;串行 &#xff08;2&#xff09;并行 &#xff08;3&#xff09;并发 三、爬虫中的线程和进程 &am…...

Tensor 基本操作2 理解 tensor.max 操作,沿着给定的 dim 是什么意思 | PyTorch 深度学习实战

前一篇文章&#xff0c;Tensor 基本操作1 | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 目录 Tensor 基本操作torch.max默认指定维度 Tensor 基本操作 torch.max torch.max 实现降维运算&#xff0c;基于指定的 d…...

[牛客]公交线路(dijkstra+链式前向星)

登录—专业IT笔试面试备考平台_牛客网 #include<bits/stdc.h> using namespace std; #define endl \n typedef long long ll; const int N1e65,M1e85; int cnt0,head[N]; int n,m,s,t; struct node {int v,w,next; }edge[M]; void addedge(int u,int v,int w) {cnt;edge…...

面试被问的一些问题汇总(持续更新)

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…...

RocketMQ原理—5.高可用+高并发+高性能架构

大纲 1.RocketMQ的整体架构与运行流程 2.基于NameServer管理Broker集群的架构 3.Broker集群的主从复制架构 4.基于Topic和Queue实现的数据分片架构 5.Broker基于Pull模式的主从复制原理 6.Broker层面到底如何做到数据0丢失 7.数据0丢失与写入高并发的取舍 8.RocketMQ读…...

适配器模式——C++实现

目录 1. 适配器模式简介 2. 角色组成 3. 代码示例 4. 适配器模式、装饰器模式、外观模式的辨析 1. 适配器模式简介 适配器模式是一种结构型模式。 适配器模式的定义&#xff1a;适配器模式将一个类的接口&#xff0c;转换成客户期望的另一个接口。适配器让原本接口不可兼容…...

C语言自定义数据类型详解(一)——结构体类型(上)

什么是自定义数据类型呢&#xff1f;顾名思义&#xff0c;就是我们用户自己定义和设置的类型。 在C语言中&#xff0c;我们的自定义数据类型一共有三种&#xff0c;它们分别是&#xff1a;结构体(struct)&#xff0c;枚举(enum)&#xff0c;联合(union)。接下来&#xff0c;我…...

C语言基础4

sizeof和strlen的区别 ①sizeof是运算符而strlen是函数 ②sizeof可以用类型做参数&#xff0c;strlen只能用char*做参数 ③数组做sizeof参数不退化&#xff0c;而传递给strlen则退化成指针 ④strlen结果是运行时候才能计算出来&#xff0c;而且计算出来的是字符串的长度不是内…...

【Elasticsearch】Elasticsearch的查询

Elasticsearch的查询 DSL查询基础语句叶子查询全文检索查询matchmulti_match 精确查询termrange 复合查询算分函数查询bool查询 排序分页基础分页深度分页 高亮高亮原理实现高亮 RestClient查询基础查询叶子查询复合查询排序和分页高亮 数据聚合DSL实现聚合Bucket聚合带条件聚合…...

第 5 章:声音与音乐系统

5.1 声音效果的应用 在游戏中&#xff0c;声音效果是增强游戏沉浸感和趣味性的重要元素。Pygame 提供了强大的音频处理功能&#xff0c;使得添加各种声音效果变得相对简单。声音效果可以包括角色的动作音效&#xff0c;如跳跃、攻击、受伤时的声音&#xff1b;环境音效&#x…...

第十四讲 JDBC数据库

1. 什么是JDBC JDBC&#xff08;Java Database Connectivity&#xff0c;Java数据库连接&#xff09;&#xff0c;它是一套用于执行SQL语句的Java API。应用程序可通过这套API连接到关系型数据库&#xff0c;并使用SQL语句来完成对数据库中数据的查询、新增、更新和删除等操作…...

2024年除夕

多少年前的除夕&#xff0c;一如今天这样的除夕&#xff1b;多少年后的除夕&#xff0c;也一如多少年前的除夕。 无数个这样的除夕下午&#xff0c;我打开电脑&#xff0c;望着窗外安静的小区&#xff0c;车声渐渐稀疏的马路&#xff0c;想写下一些新的感受时&#xff0c;多少…...

虚幻基础07:蓝图接口

能帮到你的话&#xff0c;就给个赞吧 &#x1f618; 文章目录 作用原理事件函数 作用 实现对象间的通知。 A 通知 B 做什么。 原理 将接口抽象为蓝图&#xff0c;使得任意蓝图都能直接访问。 只需要再传入对象地址&#xff0c;就能执行对象的功能。 事件 黄色&#xff1a;…...

7. 马科维茨资产组合模型+金融研报AI长文本智能体(Qwen-Long)增强方案(理论+Python实战)

目录 0. 承前1. 深度金融研报准备2. 核心AI函数代码讲解2.1 函数概述2.2 输入参数2.3 主要流程2.4 异常处理2.5 清理工作2.7 get_ai_weights函数汇总 3. 汇总代码4. 反思4.1 不足之处4.2 提升思路 5. 启后 0. 承前 本篇博文是对前两篇文章&#xff0c;链接: 5. 马科维茨资产组…...

如何在本地部署deepseek r1模型?

DeepSeek&#xff08;深度求索&#xff09;正式发布了其最新推理模型DeepSeek-R1&#xff0c;引发业界广泛关注。这款模型不仅在性能上与OpenAI的GPT-4相媲美&#xff0c;更以其开源策略和创新的训练方法&#xff0c;为AI发展带来了新的可能性。DeepSeek-R1 在后训练阶段大规模…...

HarmonyOS:状态管理最佳实践

一、概述 在声明式UI编程范式中&#xff0c;UI是应用程序状态的函数&#xff0c;应用程序状态的修改会更新相应的UI界面。ArkUI采用了MVVM模式&#xff0c;其中ViewModel将数据与视图绑定在一起&#xff0c;更新数据的时候直接更新视图。如下图所示&#xff1a; ArkUI的MVVM模式…...

当AI风暴来袭:中美科技商业版图的迥异走向

当AI风暴来袭:中美科技商业版图的迥异走向 美国科技巨头的 AI 豪赌:Stargate 公司的诞生 2025 年,科技界被一则重磅消息所震动:软银、NVIDIA、Oracle 与 OpenAI 共同组建了 Stargate 公司。这一合作堪称豪华阵容,软银作为全球知名的投资巨头,拥有雄厚的资金实力和广泛的…...

马尔科夫模型和隐马尔科夫模型区别

我用一个天气预报和海藻湿度观测的比喻来解释&#xff0c;保证你秒懂&#xff01; 1. 马尔可夫模型&#xff08;Markov Model, MM&#xff09; 特点&#xff1a;状态直接可见 场景&#xff1a;天气预报&#xff08;晴天→雨天→阴天…&#xff09;核心假设&#xff1a; 下一个…...

面向对象设计原则 - SOLID原则 (基于C++)

SOLID 是面向对象编程中的一组五个设计原则&#xff0c;这些原则旨在帮助开发者创建更灵活、可维护和可扩展的软件系统。它们最初由 Robert C. Martin 提出&#xff0c;并在 2000 年左右被广泛接受。每个字母代表一个不同的原则&#xff1a; 单一职责原则 (Single Responsibil…...

ChatGPT 搜索测试整合记忆功能

据 TestingCatalog 报道&#xff0c;OpenAI 正在测试 ChatGPT 搜索的整合记忆功能&#xff0c;被命名为 “Memory in search”2。以下是关于该功能的具体情况123&#xff1a; 功能特点 个性化搜索&#xff1a;启用该功能后&#xff0c;ChatGPT 能利用存储的记忆数据&#xff0…...

PWM频率测量方法

测量PWM&#xff08;脉宽调制&#xff09;信号的频率是嵌入式系统中的常见需求&#xff0c;尤其是在电机控制、LED调光、传感器信号处理等场景中。 在这里介绍两种测量PWM频率的方法&#xff1a;测频法与测周法。 1、测频&#xff08;率&#xff09;法 原理&#xff1a;在闸门…...

【B站保姆级视频教程:Jetson配置YOLOv11环境(一)镜像下载与烧录】

b站同步视频教程&#xff1a;https://www.bilibili.com/video/BV11r6oYkEFb/ 一、引言 在人工智能与计算机视觉快速发展的当下&#xff0c;Jetson系列开发板凭借强大的性能&#xff0c;成为众多开发者进行深度学习项目的热门选择。YOLOv11作为目标检测领域的先进算法&#xf…...

使用QSqlQueryModel创建交替背景色的表格模型

class UserModel(QSqlQueryModel):def __init__(self):super().__init__()self._query "SELECT name, age FROM users"self.refresh()def refresh(self):self.setQuery(self._query)# 重新定义data()方法def data(self, index, role): if role Qt.BackgroundRole…...

计算机网络__基础知识问答

Question: 1&#xff09;在计算机网络的5层结构中&#xff0c;每一层的功能大概是什么&#xff1f; 2&#xff09;交换机的功能&#xff1f;https://www.bilibili.com/video/BV1na4y1L7Ev 3&#xff09;路由器的功能&#xff1f;https://www.bilibili.com/video/BV1hv411k7n…...

C语言数组详解:从基础到进阶的全面解析

在C语言中&#xff0c;数组是一种基本的数据结构&#xff0c;用于存储多个相同类型的数据。数组的引入使得C语言能够高效地存储和操作大量数据。在任何一个C语言程序中&#xff0c;数组都发挥着极其重要的作用。无论是在算法实现、数据存储、还是在复杂程序的设计中&#xff0c…...

微前端架构在前端开发中的实践与挑战

随着单页面应用&#xff08;SPA&#xff09;和前端框架如 React、Vue、Angular 的快速发展&#xff0c;现代前端应用的复杂度日益提升。尤其是当应用规模逐渐增大时&#xff0c;单一的代码库往往难以应对不同团队的协作和版本管理问题。为了应对这一挑战&#xff0c;微前端架构…...

国内flutter环境部署(记录篇)

设置系统环境变量 export PUB_HOSTED_URLhttps://pub.flutter-io.cn export FLUTTER_STORAGE_BASE_URLhttps://storage.flutter-io.cn使用以下命令下载flutter镜像 git clone -b stable https://mirror.ghproxy.com/https://github.com/<github仓库地址>#例如flutter仓…...

Julia DataFrames.jl:深入理解和使用

随着数据科学和机器学习的发展&#xff0c;数据框架广泛应用于数据处理与分析工作中。在 Julia 语言中&#xff0c;DataFrames.jl 是一个强大且灵活的数据框库&#xff0c;为数据操作提供了丰富的功能。本文旨在系统地介绍 DataFrames.jl 的基础概念、使用方法、常见实践和最佳…...

上位机知识篇---DDSSDK

文章目录 前言第一部分&#xff1a;DDS核心特性1.以数据为中心2.发布-订阅模型3.质量服务4.多语言支持 关键概念1.主题2.发布者3.订阅者4. 数据写入者5.数据读取者6.域参与者7.域 DDS的优势1.可伸缩性2.实时性3.可靠性4.容错性 DDS的应用场景1.军事通信系统2.航空航天3.工业自动…...

基于DeepSeek在藏语学习推广和藏语信息化方面可以做哪些工作?

基于DeepSeek对藏语的技术优势&#xff0c;您可在以下三大方向开展创新性工作&#xff0c;以下是20具体落地方案&#xff1a; 一、藏语智能教育工具开发 《三十颂》AI语法教练 开发虚拟助教自动解析藏文句子结构&#xff08;标注格助词/时态变化&#xff09;错误检测系统&…...