rust学习笔记9-结构体与206.反转链表

结构体

rust不是面向对象语言,没有类(class),主要采用结构体(struct)来处理结构化数据,这点与go语言相似。

基本使用

struct Person {name: String,age: u32,height: f64,
}fn main() {let person = Person {name: String::from("张三"),age: 34,height: 175.0,};println!("姓名: {}, 年龄: {}, 身高: {}", person.name, person.age, person.height);
}

2. 结构体的方法
通过 impl 块为结构体定义方法:

struct Person {name: String,age: u32,height: f64,
}impl Person {// 关联函数(类似构造函数)fn new(name: &str, age: u32, height: f64) -> Person {Person {name: String::from(name),age,height,}}// 方法:打印信息fn greet(&self) {println!("我是: {}, 年龄: {}, 身高: {}", self.name, self.age, self.height);}// 方法:修改年龄fn celebrate_birthday(&mut self, age: u32) {self.age = age;println!("Happy Birthday! Now I am {} years old.", self.age);}
}fn main() {let mut person = Person::new("小红", 25, 160.0);person.greet(); // 调用方法person.celebrate_birthday(24); // 修改年龄person.greet();
}

3.结构体与所有权
Rust 的所有权规则同样适用于结构体。如果结构体包含拥有所有权的字段(如 String 或 Vec),当结构体被移动时,这些字段的所有权也会被转移。

struct Person {name: String,
}fn main() {let person = Person {name: String::from("小李"),};let another_person = person; // 所有权转移println!("{}", person.name); // 错误:`person` 已经被移动
}

4.rust结构体的可见性
结构体本身默认私有,用 pub 使其公有,这点与go语言不太一样,go是才用首字母是否大写来确定是否公有

pub struct PublicStruct {pub public_field: i32,private_field: i32,  // 默认私有
}

5.应用练习

206. 反转链表

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

示例 1:

输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]

示例 2:

输入:head = [1,2]
输出:[2,1]

示例 3:

输入:head = []
输出:[]

提示:

  • 链表中节点的数目范围是 [0, 5000]
  • -5000 <= Node.val <= 5000

进阶:链表可以选用迭代或递归方式完成反转。你能否用两种方法解决这道题?

(1)先定义数据库结构,直接从力扣上获取

 //Definition for singly-linked list.#[derive(PartialEq, Eq, Clone, Debug)]pub struct ListNode {pub val: i32,pub next: Option<Box<ListNode>>}impl ListNode {#[inline]fn new(val: i32) -> Self {ListNode {next: None,val}}}

 注 Box<T> 是 Rust 中最简单的智能指针之一,它允许在堆上分配一块内存,并将值存储在这个内存中,目前智能指针还没学,暂时先了解一下,不用深究

(2)节点为空判断,由于 Rust 不支持 null ,这就很难受了,不光链表,后面的栈、队列、二叉树等都免不了要判断为空的情况,这怎么办呢,那就是用上一篇说的,用Option枚举类型,用Option可以有效处理节点为空的情况,可以用if也可以用match模式匹配,考虑目前还不是很熟,match不易理解,先用if,后面再用match

fn main() { // 创建单个节点let node1 = ListNode::new(1); // 值为 1 的节点println!("单个节点: {:?}", node1);let head = Some(Box::new(node1)); // 确保 head 是 Option<Box<ListNode>>if let Some(node) = head {println!("节点不为空, 值是: {}", node.val);} else {println!("节点为空");}//创建空节点let head :Option<Box<ListNode>> = None;if let Some(node) = head {println!("节点不为空, 值是: {}", node.val);} else {println!("节点为空");}
}

(3)解题原始版本

pub fn reverse_list(head: Option<Box<ListNode>>) -> Option<Box<ListNode>> {let mut cur = head;let mut pre: Option<Box<ListNode>> = None;loop {if let Some(mut node) = cur {// 使用 take 取出 node.next 的值,并将 node.next 设置为 Nonecur = node.next.take(); node.next = pre;        // 将前一个节点赋值给当前节点的 nextpre = Some(node);       // 更新 pre 为当前节点} else {break;}} return pre;}

简化版

pub fn reverse_list(head: Option<Box<ListNode>>) -> Option<Box<ListNode>> {let mut cur = head;let mut pre: Option<Box<ListNode>> = None;while let Some(mut node) = cur.take() {cur = node.next;node.next = pre;  pre = Some(node);      }return pre;
}

 运行结果

总结结构体是rust重要是数据结构,需要重点掌握,未来无论刷题还是做项目都会大量用到。再处理链表这类复杂的数据结构,特别是为空判断,可以使用Option枚举类型,来处理这种情况。

解题思路,首先先屏蔽一些不易理解的内容,如智能指针Box<T>、match模式匹配不易理解,先用if,递归等学到函数递归再用,然后逐个解决,先解决为空判断,然后再解题就很轻松了。

take函数

Option::take 的定义

pub fn take(&mut self) -> Option<T>

功能:从一个可变引用中取出当前的值,并将该 Option<T> 设置为 None。
返回值:返回当前的 Option<T> 值(可能是 Some(T) 或 None)。
通过这种方式,take 方法允许你在不破坏原始 Option<T> 的情况下,安全地获取其内部值。

cur.take();  // 使用 take 取出 cur的值,并将 cur设置为 None,这样所有权不用发生转移,特别适合处理链表这种复杂的数据结构,安全高效

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

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

相关文章

DDD该怎么去落地实现(4)多对多关系

多对多关系的设计实现 如题&#xff0c;DDD该如何落地呢&#xff1f;前面我通过三期的内容&#xff0c;讲解了DDD落地的关键在于“关系”&#xff0c;也就是通过前面我们对业务的理解先形成领域模型&#xff0c;然后将领域模型的原貌&#xff0c;形成程序代码中的服务、实体、…

论文阅读:CAN GENERATIVE LARGE LANGUAGE MODELS PERFORM ASR ERROR CORRECTION?

CAN GENERATIVE LARGE LANGUAGE MODELS PERFORM ASR ERROR CORRECTION? 生成式大语言模型能否进行自动语音识别&#xff08;ASR&#xff09;纠错&#xff1f; https://arxiv.org/pdf/2307.04172 文章目录 速览常规总结通俗版 摘要&#xff08;Abstract&#xff09;2. 引言&a…

python面向对象

目录 初识对象 类的成员方法 类和对象 构造方法 魔术方法 __str__ __lt__ __le__ __eq__ 封装 私有成员 继承 单继承 多继承 pass 复写 类型注解 1 变量的类型注解 方法1 使用: 方法2 注释 应用场景 2 函数(方法)的类型注解 3 混合类型注解 多态 初识对象 #设计…

C++的类型转换

C语言中的类型转换 在C语言中&#xff0c;如果赋值运算符左右两侧类型不同&#xff0c;或者形参与实参类型不匹配&#xff0c;或者返回值类型与 接收返回值类型不一致时&#xff0c;就需要发生类型转化&#xff0c;C语言中总共有两种形式的类型转换&#xff1a;隐式类型 转换和…

计算机网络-实验3拓扑结构

三、实验拓扑结构、实验步骤及结果分析 1. 实验拓扑结构 2. 实验步骤 3. 结果分析

[ISP] AE 自动曝光

相机通过不同曝光参数&#xff08;档位快门时间 x 感光度 x 光圈大小&#xff09;控制进光量来完成恰当的曝光。 自动曝光流程大概分为三部分&#xff1a; 1. 测光&#xff1a;点测光、中心测光、全局测光等&#xff1b;通过调整曝光档位使sensor曝光在合理的阈值内&#xff0…

聊一聊 IM 如何优化架构?

IM 系列 im doc 实时通讯文档仓库 聊一聊 IM 是什么&#xff1f; IM 即时通讯系统概览 聊一聊 IM 要如何设计&#xff1f; 聊一聊 IM 要如何设计功能模块&#xff1f; 聊一聊 IM 要如何进行架构设计&#xff1f; 聊一聊 IM 要如何进行技术选型&#xff1f; 聊一聊 IM 要…

开启mysql的binlog日志

mysql版本5.7 1.查看是否开启bin_log show global variables like’log_bin’; off的话需要先开启 在mysql的文件夹目录中找到my.ini 加一行log-bin“C:/ProgramData/MySQL/MySQL Server 5.7/logs/log-bin” 并提前创建好目录 2.数据库会把日志放进logs目录中 3.查看log日…

OpenHarmony4.1-轻量与小型系统ubuntu开发环境

因OpenHarmony官网提供包含轻量、小型与标准系统的全量代码非常宠大&#xff0c;解包后大概需要70G以上硬盘空间&#xff0c;如要编译标准系统则需要140G以上空间。 如硬盘空间有限与只使用轻量/小型OpenHarmony系统&#xff0c;则可以下载并直接使用本人裁剪源码过的ubuntu硬盘…

图论题目。

图论题目 检测环(dfsbfs)课程表 拓扑排序&#xff08;dfsbfs&#xff09;课程表2 二分图&#xff08;dfs,bfs&#xff09;判断二分图可能的二分法 Kruskal算法和Prim算法连接所有点的最小费用 Dijkstra算法概率最大的路径网络延时时间 检测环(dfsbfs) 课程表 题目 dfs: clas…

2025春新生培训数据结构(树,图)

教学目标&#xff1a; 1&#xff0c;清楚什么是树和图&#xff0c;了解基本概念&#xff0c;并且理解其应用场景 2&#xff0c;掌握一种建图&#xff08;树&#xff09;方法 3&#xff0c;掌握图的dfs和树的前中后序遍历 例题与习题 2025NENU新生培训&#xff08;树&#…

如何防止Python网络爬虫爬取网站内容

要防止Python网络爬虫爬取网站内容&#xff0c;可以从以下几个方面入手&#xff1a; 遵守Robots.txt文件&#xff1a;首先&#xff0c;网站管理员可以通过robots.txt文件明确告知爬虫哪些页面可以抓取&#xff0c;哪些不可以。爬虫在抓取之前应先检查该文件&#xff0c;尊重网站…

Java数据结构第十六期:走进二叉树的奇妙世界(五)

专栏&#xff1a;Java数据结构秘籍 个人主页&#xff1a;手握风云 目录 一、非递归实现遍历二叉树 1.1. 二叉树的前序遍历 1.2. 二叉树的中序遍历 1.3. 二叉树的后序遍历 一、非递归实现遍历二叉树 1.1. 二叉树的前序遍历 我们这里要使用栈来进行实现。我们反向思考一下为…

yolov8_pose模型,使用rknn在安卓RK3568上使用

最近在使用rknn的一些功能,看了看文档以及自己做的一些jni,使用上yolov8_pose的模型. 1.我们先下载一下rknn的模型功能代码,rk有自己做的一套demo 地址:GitHub - airockchip/rknn_model_zooContribute to airockchip/rknn_model_zoo development by creating an account on G…

大模型推理时的尺度扩展定律

大模型推理时的尺度扩展定律 FesianXu at 20250212 at Wechat Search Team 前言 大模型的尺度扩展定律告诉我们&#xff1a;『LLM的性能会随着模型的参数量、模型的训练量、模型的训练数据量的增加而增加』。训练存在尺度扩展定律&#xff0c;测试也存在尺度扩展定律&#xff…

ubuntu防火墙iptables

文章目录 步骤开启自启防火墙iptables规则链Chains的区别 在 Ubuntu 上使用 iptables 配置防火墙并保证服务可用 步骤 #防火墙状态 systemctl status iptables systemctl start iptables #开启防火墙并且开启22端口 systemctl start iptables && iptables -A INPUT -p…

聊一聊 IM 如何优化监控

IM 系列 im doc 实时通讯文档仓库 聊一聊 IM 是什么&#xff1f; IM 即时通讯系统概览 聊一聊 IM 要如何设计&#xff1f; 聊一聊 IM 要如何设计功能模块&#xff1f; 聊一聊 IM 要如何进行架构设计&#xff1f; 聊一聊 IM 要如何进行技术选型&#xff1f; 聊一聊 IM 要…

[Windows] 批量为视频或者音频生成字幕 video subtitle master 1.5.2

Video Subtitle Master 1.5.2 介绍 Video Subtitle Master 1.5.2 是一款功能强大的客户端工具&#xff0c;能够批量为视频或音频生成字幕&#xff0c;还支持批量将字幕翻译成其他语言。该工具具有跨平台性&#xff0c;无论是 mac 系统还是 windows 系统都能使用。 参考原文&a…

探索紧急灾难处理的智慧:基于Neo4j的知识图谱问答系统

探索紧急灾难处理的智慧&#xff1a;基于Neo4j的知识图谱问答系统 在灾难突发的瞬间&#xff0c;时间就是生命&#xff01;我们为您带来了一款基于Neo4j的紧急灾难突发处理知识图谱问答系统&#xff0c;助您快速获取至关重要的信息&#xff0c;提升应急响应效率&#xff01; …

蓝桥杯(握手问题)

小蓝组织了一场算法交流会议&#xff0c;总共有 50 人参加了本次会议。在会议上&#xff0c;大家进行了握手交流。按照惯例他们每个人都要与除自己以外的其他所有人进行一次握手 (且仅有一次)。 但有 7个人&#xff0c;这 7 人彼此之间没有进行握手 (但这 7 人与除这 7 人以外…