精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

用Rust實現簡單的單鏈表

開發
作為初學者,在掌握了Rust的基本語法和所有權機制,嘗試寫一下常見數據結構和算法,目標是為了更好的理解Rust的所有權機制。 受限于個人目前對Rust仍處于入門階段,因此本文代碼實現不一定是最合適的,甚至可能存在問題。

作為初學者,在掌握了Rust的基本語法和所有權機制,嘗試寫一下常見數據結構和算法,目標是為了更好的理解Rust的所有權機制。 受限于個人目前對Rust仍處于入門階段,因此本文代碼實現不一定是最合適的,甚至可能存在問題。

今天的目標是用rust實現一個簡單的單鏈表LinkedList,同時為此鏈表提供從頭部插入元素(頭插法)、翻轉鏈表、打印鏈表的功能。

1.鏈表節點的定義

實現鏈表,首先是實現鏈表的節點,根據其他編程語言的經驗,于是用rust首先寫出了下面的鏈表節點結構體定義:

代碼片段1:

struct Node {
data: T,
next: Option>, // recursive type `Node` has infinite size
}

在代碼片段1中,定義一個Node結構體,data字段使用了泛型類型T用于鏈表節點的數據。 next使用了Option枚舉,即如果該節點沒有下一個節點時,next是可空的,在rust中沒有其他編程語言中的空值(null, nil),而是提供了Option的解決方案,如果該鏈表節點的下個節點為空,則其next取值為Option::None。

遺憾的是代碼片段1是無法編譯通過的,報了recursive type ``Node`` has infinite size的編譯錯誤。回顧Rust內存管理的基礎知識,Rust需要在編譯時知道一個類型占用多少空間,Node結構體內部嵌套了它自己,這樣在編譯時就無法確認其占用空間大小了。 在Rust中當有一個在編譯時未知大小的類型,而又想要在需要確切大小的上下文中使用這個類型值的時候,可以使用智能指針Box。將next字段的類型修改為Option>>,這樣嵌套的類型為Box,嵌套的Node將會被分配到堆上,next字段在棧上存儲的只是智能指針Box的數據(ptr, meta),這樣在編譯時就能確定Node類型的大小了。將代碼片段1的修改如下:

代碼片段2:

struct Node {
data: T,
next: Option>>,
}

修改完成后,可以編譯通過了。根據next: Option>>,每個鏈表節點Node將擁有它下一個節點Node的所有權。

2.鏈表的定義

定義完鏈表之后,下一步再定義一個結構體LinkedList用來表示鏈表,將會封裝一些鏈表的基本操作。 結構體中只需方一個鏈表頭節點的字段head,類型為Option>>。

代碼片段3:

/// 單鏈表節點
#[derive(Debug)]
struct Node {
data: T,
next: Option>>,
}
/// 單鏈表
#[derive(Debug)]
struct LinkedList {
head: Option>>,
}

為了便于使用,再給Node和LinkedList這兩個結構體各添加一下關聯函數new。

代碼片段4:

impl<T> Node<T> {
fn new(data: T) -> Self {
Self { data: data, next: None }
}
}

impl<T> LinkedList<T> {
fn new() -> Self {
Self { head: None }
}
}

Node的new函數用來使用給定的data數據創建一個孤零零的(沒有下一個節點的)節點。

LinkedList的new函數用來創建一個空鏈表。

3.實現從鏈表頭部插入節點的prepend方法

前面已經完成了鏈表和鏈表節點的定義,下面我們為鏈表實現了prepend方法,這個方法將采用頭插法的方式向鏈表中添加節點。

代碼片段5:

impl<T> LinkedList<T> {
fn new() -> Self {
Self { head: None }
}

/// 在鏈表頭部插入節點(頭插法push front)
fn prepend(&mut self, data: T) -> &mut Self {
// 從傳入數據構建要插入的節點
let mut new_node = Box::new(Node::new(data));
match self.head {
// 當前鏈表為空時, 插入的節點直接作為頭節點
None => self.head = Some(new_node),
// 當前鏈表非空時, 插入的節點作為新的頭節點插入到原來的頭結點前面
Some(_) => {
// 調用Option的take方法取出Option中的頭結點(take的內部實現是mem::replace可避免內存拷貝), 作為新插入節點的下一個節點
new_node.next = self.head.take();
// 將新插入的節點作為鏈表的頭節點
self.head = Some(new_node);
}
}
self
}
}

fn main() {
let mut ll = LinkedList::new();
ll.prepend(5).prepend(4).prepend(3).prepend(2).prepend(1);
print!("{ll:?}"); // LinkedList { head: Some(Node { data: 1, next: Some(Node { data: 2, next: Some(Node { data: 3, next: Some(Node { data: 4, next: Some(Node { data: 5, next: None }) }) }) }) }) }
}

4.為鏈表實現Display trait定制鏈表的打印顯示

前面我們實現了鏈表頭部插入節點的prepend方法,并在main函數中構建了一個鏈表,以Debug的形式打印出了鏈表的信息。

為了使打印信息更好看,我們決定為LinkedList實現Display trait,使鏈表打印的格式類似為1 -> 2 -> 3 -> 4 -> 5 -> None。

代碼片段6:

use std::fmt::Display;

......

impl<T: Display> Display for LinkedList<T> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
if self.head.is_none() {
// 如果鏈表為空, 只打印None
write!(f, "None\n")?;
} else {
// 下面將遍歷鏈表, 因為只是打印, 能獲取鏈表各個節點的數據就行, 所以不需要獲取所有權
let mut next = self.head.as_ref();
while let Some(node) = next {
write!(f, "{} -> ", node.data)?;
next = node.next.as_ref();
}
write!(f, "None\n")?;
}
Ok(())
}
}

fn main() {
let mut ll = LinkedList::new();
ll.prepend(5).prepend(4).prepend(3).prepend(2).prepend(1);
print!("{ll}"); // 1 -> 2 -> 3 -> 4 -> 5 -> None
}

5.為鏈表實現翻轉鏈表功能的reverse方法

代碼片段7:

impl<T> LinkedList<T> {
......

/// 翻轉鏈表
fn reverse(&mut self) {
let mut prev = None; // 記錄遍歷鏈表時的前一個節點
while let Some(mut node) = self.head.take() {
self.head = node.next;
node.next = prev;
prev = Some(node);
}
self.head = prev;
}
}

fn main() {
let mut ll = LinkedList::new();
ll.prepend(5).prepend(4).prepend(3).prepend(2).prepend(1);
println!("{ll}"); // 1 -> 2 -> 3 -> 4 -> 5 -> None
ll.reverse(); // 5 -> 4 -> 3 -> 2 -> 1 -> None
println!("{ll}");
}
責任編輯:未麗燕 來源: 今日頭條
相關推薦

2009-11-25 10:31:35

PHP數組實現單鏈表

2024-12-23 06:10:00

RustRigAI Agent

2024-06-10 23:07:05

2024-04-26 00:02:00

Rust語言LinkedList

2023-06-19 14:14:24

Rust程序Web

2022-08-15 08:49:06

Go版本單例模式

2022-09-05 15:18:23

HDF單鏈表嵌入式系統

2020-02-07 11:07:53

數組鏈表單鏈表

2009-08-19 04:14:00

線性鏈表

2021-04-29 08:00:00

Windows微軟安全

2021-07-13 07:52:03

Python數據結構

2018-06-25 09:54:14

LinuxDNS負載均衡

2011-07-20 14:33:19

C++IO

2020-06-04 12:55:44

PyTorch分類器神經網絡

2023-09-21 11:39:29

RustJetBrainsIDE

2021-06-03 07:45:25

Rust Git 終端 UI

2020-10-28 10:10:03

Java單鏈表數據結構

2020-06-17 16:38:22

Rust業務架構

2022-05-09 10:36:05

PythonPyScript開發者

2013-10-16 16:15:26

單鏈表
點贊
收藏

51CTO技術棧公眾號

欧美成人免费观看视频| 少妇黄色一级片| 五月激情婷婷综合| 视频一区中文字幕| 久久久精品国产亚洲| 激情小说欧美色图| 日韩电影免费观| 亚洲人精品午夜| 久久这里精品国产99丫e6| 成人黄色激情视频| 精品二区久久| 中文日韩电影网站| 久久久久麻豆v国产精华液好用吗| 亚洲精品555| 亚洲国产乱码最新视频 | 看全色黄大色大片免费久久久| 色婷婷久久99综合精品jk白丝| 麻豆中文字幕在线观看| 亚洲日本在线播放| 国产真实乱子伦精品视频| 亚洲91精品在线观看| 极品尤物一区二区| 老司机aⅴ在线精品导航| 欧美日韩在线播放一区| 99精品免费在线观看| www在线免费观看视频| 久久丝袜美腿综合| 国产精品久久7| 97国产成人无码精品久久久| 麻豆成人在线| 国a精品视频大全| 国产精品老熟女一区二区| av资源久久| 精品亚洲夜色av98在线观看| 免费在线观看日韩av| 日日狠狠久久| 欧美日韩一区二区三区高清| 日日橹狠狠爱欧美超碰| 日韩av激情| 亚洲欧美一区二区不卡| 爱爱爱视频网站| av影片免费在线观看| xf在线a精品一区二区视频网站| 成人18视频| 91亚洲精品国偷拍自产在线观看| 日韩中文字幕一区二区三区| 欧美亚洲视频在线看网址| 日韩精品一区二区av| 黄色国产精品| 久久噜噜噜精品国产亚洲综合| 欧美交换国产一区内射| 欧美aa国产视频| 欧美成人精品激情在线观看| 综合五月激情网| **女人18毛片一区二区| 美日韩精品视频免费看| www.av免费| 欧美日韩精品免费观看视频完整| 久久在线观看视频| 成人免费黄色小视频| 自拍日韩欧美| 色综合久久精品亚洲国产| 久一视频在线观看| 亚洲福利国产| 热99精品只有里视频精品| 无码人妻av一区二区三区波多野 | 亚洲成人一区在线| 成人小视频在线观看免费| japanese色国产在线看视频| 午夜精品福利一区二区三区蜜桃| 97国产在线播放| 自拍偷自拍亚洲精品被多人伦好爽 | 精品国产三级a在线观看| 无码人妻一区二区三区在线| 欧美大片网址| 国产亚洲欧美aaaa| 日本 欧美 国产| 欧美在线视屏| 97色在线视频观看| 成人免费视频国产免费| 九九**精品视频免费播放| 亚洲自拍偷拍区| 手机av免费在线观看| 久久人人97超碰com| 亚洲欧美日韩不卡一区二区三区| 尤物在线网址| 欧美小视频在线观看| 冲田杏梨av在线| 日本免费精品| 亚洲人成绝费网站色www| 美女av免费看| 国产精品扒开腿做爽爽爽软件| 欧美一级视频一区二区| 中文字幕你懂的| 丁香网亚洲国际| 欧美日韩喷水| а√中文在线8| 欧美午夜精品伦理| 在线视频观看91| 日韩欧美ww| 久久国产精品99国产精| 成年人视频在线免费看| 久88久久88久久久| 欧美日韩精品免费看| 最爽无遮挡行房视频在线| 在线这里只有精品| 日本精品一二三| 欧美aaaa视频| 欧美一区二粉嫩精品国产一线天| 国产又黄又粗又硬| ww亚洲ww在线观看国产| 国产成人生活片| 色综合天天色| 亚洲精品福利资源站| 中文字幕电影av| 日本v片在线高清不卡在线观看| 91亚色免费| 电影在线一区| 午夜成人免费视频| 最好看的中文字幕| 日韩在线观看一区| 欧美一区二区视频97| 欧美性受xxxx狂喷水| 亚洲视频免费在线| 亚洲黄色av网址| 一区二区三区日本久久久 | 九色porny丨国产精品| 欧美成人dvd在线视频| 国内老司机av在线| 欧美一区二区三区四区高清| 内射毛片内射国产夫妻| 亚洲一区二区毛片| 国产精品日本一区二区| 2024最新电影在线免费观看| 欧美另类videos死尸| 性猛交娇小69hd| 久久一本综合频道| 欧美日韩综合精品| 9i看片成人免费高清| 亚洲精品成人久久久| 久久网一区二区| 国产高清成人在线| 超碰97在线看| 免费观看性欧美大片无片| 久久网福利资源网站| 国产精品久久久久久免费| 国产精品视频在线看| 亚洲污视频在线观看| 日本久久黄色| 国产综合在线观看视频| 欧美一级二级三级区| 欧美日韩一级片网站| avhd101老司机| 久久精品久久精品| 亚洲一区三区视频在线观看 | 欧美日韩国产综合久久| 在线免费观看视频| 蜜臀av一区二区三区| 婷婷亚洲婷婷综合色香五月| 欧美黄色成人| 久久成人精品电影| 亚洲av无码国产综合专区| 亚洲福中文字幕伊人影院| 亚洲天堂美女视频| 男女av一区三区二区色多| 欧美精品免费观看二区| 国产成人精品一区二区三区在线 | 亚洲精品永久www嫩草| 激情中国色综合| 欧美成人剧情片在线观看| 懂色av成人一区二区三区| 红桃视频成人在线观看| 久久精品国产亚洲AV熟女| 免费精品视频最新在线| 免费成人进口网站| y111111国产精品久久久| 57pao成人国产永久免费| 国产三级在线| 欧美一区二区三区视频| 国产成人亚洲精品自产在线| 欧美国产视频在线| 中文字幕在线视频一区二区| 最新成人av网站| 日韩精品资源| 秋霞影院一区| 日韩av三级在线观看| 欧美成年黄网站色视频| 精品国产91乱码一区二区三区 | 北条麻妃在线观看视频| 国产99久久久国产精品潘金| 日韩少妇内射免费播放18禁裸乳| 欧美综合在线视频观看 | 精品国产av一区二区| 激情成人在线视频| 貂蝉被到爽流白浆在线观看| 国产成人在线观看免费网站| 国产激情在线观看视频| 午夜久久一区| 亚洲一区二区三区色| 人体久久天天| 99九九电视剧免费观看| 欧美亚洲大片| 久久久久久亚洲精品| www.亚洲视频| 日韩的一区二区| 精品国产乱码一区二区三| 91国产精品成人| 天堂资源在线播放| 日韩一区欧美小说| 男人舔女人下部高潮全视频| 成人黄色777网| 成人亚洲免费视频| 久久久久久久波多野高潮日日| 成年人深夜视频| 欧美1级片网站| 日本不卡久久| 日韩电影不卡一区| 97se在线视频| 欧美综合影院| 国产精品高潮呻吟视频| 国产在线精彩视频| 久久999免费视频| 老司机在线永久免费观看| 亚洲欧美另类在线观看| 色婷婷av一区二区三区之红樱桃| 日韩欧美一区二区视频| 国产精品福利电影| 欧美午夜在线一二页| 人妻丰满熟妇av无码区| 亚洲国产视频一区| 九九热精彩视频| 亚洲视频狠狠干| 国产精品69久久久久孕妇欧美| 26uuu国产在线精品一区二区| jjzzjjzz欧美69巨大| 高清在线观看日韩| gogo亚洲国模私拍人体| 激情综合色综合久久综合| 免费成年人高清视频| 另类的小说在线视频另类成人小视频在线| 亚洲成熟丰满熟妇高潮xxxxx| 亚洲黄色免费| 国产原创popny丨九色| 国产一区成人| 成熟老妇女视频| 久久午夜影视| 日本va中文字幕| 奇米888四色在线精品| 黄色片在线免费| 免费日本视频一区| 亚洲精品综合在线观看| 国产真实乱子伦精品视频| 特级黄色片视频| 粉嫩av一区二区三区粉嫩| 免费欧美一级片| 成人av在线一区二区| 亚洲国产精品成人综合久久久| 91在线高清观看| 色一情一交一乱一区二区三区 | 国产视频亚洲视频| 精品av中文字幕在线毛片| 亚洲新中文字幕| 麻豆视频在线观看免费网站| 欧美激情视频一区| 91jq激情在线观看| 欧美专区中文字幕| 国产国产一区| 99理论电影网| 欧洲精品一区| 亚洲精品一区二区三区av| 欧美在线影院| 成人一对一视频| 奇米精品一区二区三区在线观看| 欧美成人手机在线视频| 丁香啪啪综合成人亚洲小说| 白嫩情侣偷拍呻吟刺激| 久久久久久久久久久久久女国产乱| 久久久久久成人网| 一区二区三区av电影| 特级西西444www大精品视频免费看| 在线日韩av片| 不卡视频在线播放| 亚洲另类激情图| а√中文在线8| 日韩av电影院| 美女精品视频在线| 欧美一区二区三区在线免费观看| 国产精品久久久久久久| 日韩欧美一区二| 精品一区在线看| 朝桐光av一区二区三区| 亚洲欧美综合网| 久久一区二区三区视频| 欧美精品第1页| 四虎国产精品永远| www.xxxx欧美| 欧美性xxx| 不卡一区二区三区视频| 国产99久久| 日b视频免费观看| 免费美女久久99| 泷泽萝拉在线播放| 亚洲三级理论片| 久久久精品毛片| 亚洲高清一区二| 免费a在线看| 国产精品久久久久久久9999 | 日本亚洲自拍| 激情五月***国产精品| 蜜臀一区二区三区精品免费视频| av激情综合网| 久久久久亚洲av片无码下载蜜桃| 欧美亚洲愉拍一区二区| 日韩美女一级视频| 久久久久成人网| 国产精品视频首页| 日韩亚洲欧美精品| 国产精品久久国产愉拍| 欧洲成人午夜精品无码区久久| 中文欧美字幕免费| 中文字幕黄色片| 亚洲国产女人aaa毛片在线| 91香蕉在线观看| 5566av亚洲| 我不卡伦不卡影院| 国产色视频在线播放| 2024国产精品| 欧美一级片免费在线观看| 欧美精品一区二区三区蜜臀| 182tv在线播放| 97久久精品午夜一区二区| 亚洲二区三区不卡| www.99r| 国产精品伦一区| 中文字幕一区二区三区免费看| 亚洲日本欧美中文幕| 日本免费一区二区三区四区| 久久精品女人的天堂av| 亚洲久久视频| 捆绑裸体绳奴bdsm亚洲| 亚洲18女电影在线观看| 丰满人妻一区二区三区无码av| 欧美激情xxxx| 久久精品色综合| 欧美亚洲精品一区二区| 91视频免费播放| 国产嫩bbwbbw高潮| 亚洲欧美国产精品| 久久91导航| 亚洲精品日韩精品| 久久99最新地址| 欧美另类视频在线观看| 日韩欧美激情四射| 第一av在线| 欧美凹凸一区二区三区视频| 老司机免费视频久久| 婷婷丁香综合网| 欧美一区二区高清| 超碰在线97国产| 久久久www免费人成黑人精品| 久久av在线| 激情五月激情综合| 欧美一区二区三区在| 国产黄色大片在线观看| 久久本道综合色狠狠五月| 久久精品天堂| 国产一级淫片久久久片a级| 欧美一区二区三区成人| 啪啪免费视频一区| 精品国产91亚洲一区二区三区www| 久久在线91| 日本高清不卡免费| 精品国产成人系列| 中文字幕系列一区| 18视频在线观看娇喘| 成人av免费在线播放| 在线观看污污网站| 欧美成人午夜激情在线| 欧美大片网址| 国产无遮挡猛进猛出免费软件 | 成人免费毛片视频| xxx成人少妇69| 国产精品对白| 亚洲 欧美 另类人妖| 亚洲线精品一区二区三区八戒| 亚洲 精品 综合 精品 自拍| 国产精品亚洲网站| 亚洲激情网站| 蜜桃av.com| 日韩成人中文字幕在线观看| 性欧美video另类hd尤物| 黄网站欧美内射| 18欧美乱大交hd1984| 亚洲欧洲视频在线观看| 国产欧美在线看| 先锋a资源在线看亚洲| 成人免费视频网站入口::| 亚洲欧美国内爽妇网| 一区二区免费| 日日噜噜夜夜狠狠|