From b0c147b67c698559287a951699c7ef7d38ec45f3 Mon Sep 17 00:00:00 2001 From: rongyi Date: Thu, 10 Jul 2025 06:33:22 +0800 Subject: [PATCH] Polish rust (#1777) * Polish rust * Update array queue and linkedlist queue * Update linkedlist deque * make array deque generic --- .../chapter_array_and_linkedlist/my_list.rs | 2 +- codes/rust/chapter_heap/heap.rs | 10 ------- .../chapter_stack_and_queue/array_deque.rs | 26 +++++++++---------- .../chapter_stack_and_queue/array_queue.rs | 20 +++++++------- .../linkedlist_deque.rs | 6 ++--- .../linkedlist_queue.rs | 2 +- .../linkedlist_stack.rs | 20 ++++++++------ codes/rust/src/include/tree_node.rs | 2 +- 8 files changed, 41 insertions(+), 47 deletions(-) diff --git a/codes/rust/chapter_array_and_linkedlist/my_list.rs b/codes/rust/chapter_array_and_linkedlist/my_list.rs index 1ed707306..566f8d830 100644 --- a/codes/rust/chapter_array_and_linkedlist/my_list.rs +++ b/codes/rust/chapter_array_and_linkedlist/my_list.rs @@ -90,7 +90,7 @@ impl MyList { panic!("索引越界") }; let num = self.arr[index]; - // 将将索引 index 之后的元素都向前移动一位 + // 将索引 index 之后的元素都向前移动一位 for j in index..self.size - 1 { self.arr[j] = self.arr[j + 1]; } diff --git a/codes/rust/chapter_heap/heap.rs b/codes/rust/chapter_heap/heap.rs index 8bb0c6ba7..7281865a4 100644 --- a/codes/rust/chapter_heap/heap.rs +++ b/codes/rust/chapter_heap/heap.rs @@ -13,22 +13,12 @@ fn test_push_max(heap: &mut BinaryHeap, val: i32) { println!("\n元素 {} 入堆后", val); print_util::print_heap(heap.iter().map(|&val| val).collect()); } -fn test_push_min(heap: &mut BinaryHeap>, val: i32) { - heap.push(Reverse(val)); // 元素入堆 - println!("\n元素 {} 入堆后", val); - print_util::print_heap(heap.iter().map(|&val| val.0).collect()); -} fn test_pop_max(heap: &mut BinaryHeap) { let val = heap.pop().unwrap(); println!("\n堆顶元素 {} 出堆后", val); print_util::print_heap(heap.iter().map(|&val| val).collect()); } -fn test_pop_min(heap: &mut BinaryHeap>) { - let val = heap.pop().unwrap().0; - println!("\n堆顶元素 {} 出堆后", val); - print_util::print_heap(heap.iter().map(|&val| val.0).collect()); -} /* Driver Code */ fn main() { diff --git a/codes/rust/chapter_stack_and_queue/array_deque.rs b/codes/rust/chapter_stack_and_queue/array_deque.rs index 905c371fb..97b051279 100644 --- a/codes/rust/chapter_stack_and_queue/array_deque.rs +++ b/codes/rust/chapter_stack_and_queue/array_deque.rs @@ -5,17 +5,17 @@ */ use hello_algo_rust::include::print_util; /* 基于环形数组实现的双向队列 */ -struct ArrayDeque { - nums: Vec, // 用于存储双向队列元素的数组 +struct ArrayDeque { + nums: Vec, // 用于存储双向队列元素的数组 front: usize, // 队首指针,指向队首元素 que_size: usize, // 双向队列长度 } -impl ArrayDeque { +impl ArrayDeque { /* 构造方法 */ pub fn new(capacity: usize) -> Self { Self { - nums: vec![0; capacity], + nums: vec![T::default(); capacity], front: 0, que_size: 0, } @@ -41,11 +41,11 @@ impl ArrayDeque { // 通过取余操作实现数组首尾相连 // 当 i 越过数组尾部后,回到头部 // 当 i 越过数组头部后,回到尾部 - return ((i + self.capacity() as i32) % self.capacity() as i32) as usize; + ((i + self.capacity() as i32) % self.capacity() as i32) as usize } /* 队首入队 */ - pub fn push_first(&mut self, num: i32) { + pub fn push_first(&mut self, num: T) { if self.que_size == self.capacity() { println!("双向队列已满"); return; @@ -59,7 +59,7 @@ impl ArrayDeque { } /* 队尾入队 */ - pub fn push_last(&mut self, num: i32) { + pub fn push_last(&mut self, num: T) { if self.que_size == self.capacity() { println!("双向队列已满"); return; @@ -72,7 +72,7 @@ impl ArrayDeque { } /* 队首出队 */ - fn pop_first(&mut self) -> i32 { + fn pop_first(&mut self) -> T { let num = self.peek_first(); // 队首指针向后移动一位 self.front = self.index(self.front as i32 + 1); @@ -81,14 +81,14 @@ impl ArrayDeque { } /* 队尾出队 */ - fn pop_last(&mut self) -> i32 { + fn pop_last(&mut self) -> T { let num = self.peek_last(); self.que_size -= 1; num } /* 访问队首元素 */ - fn peek_first(&self) -> i32 { + fn peek_first(&self) -> T { if self.is_empty() { panic!("双向队列为空") }; @@ -96,7 +96,7 @@ impl ArrayDeque { } /* 访问队尾元素 */ - fn peek_last(&self) -> i32 { + fn peek_last(&self) -> T { if self.is_empty() { panic!("双向队列为空") }; @@ -106,9 +106,9 @@ impl ArrayDeque { } /* 返回数组用于打印 */ - fn to_array(&self) -> Vec { + fn to_array(&self) -> Vec { // 仅转换有效长度范围内的列表元素 - let mut res = vec![0; self.que_size]; + let mut res = vec![T::default(); self.que_size]; let mut j = self.front; for i in 0..self.que_size { res[i] = self.nums[self.index(j as i32)]; diff --git a/codes/rust/chapter_stack_and_queue/array_queue.rs b/codes/rust/chapter_stack_and_queue/array_queue.rs index 6f2af5731..62423fa1d 100644 --- a/codes/rust/chapter_stack_and_queue/array_queue.rs +++ b/codes/rust/chapter_stack_and_queue/array_queue.rs @@ -5,18 +5,18 @@ */ /* 基于环形数组实现的队列 */ -struct ArrayQueue { - nums: Vec, // 用于存储队列元素的数组 +struct ArrayQueue { + nums: Vec, // 用于存储队列元素的数组 front: i32, // 队首指针,指向队首元素 que_size: i32, // 队列长度 que_capacity: i32, // 队列容量 } -impl ArrayQueue { +impl ArrayQueue { /* 构造方法 */ - fn new(capacity: i32) -> ArrayQueue { + fn new(capacity: i32) -> ArrayQueue { ArrayQueue { - nums: vec![0; capacity as usize], + nums: vec![T::default(); capacity as usize], front: 0, que_size: 0, que_capacity: capacity, @@ -39,7 +39,7 @@ impl ArrayQueue { } /* 入队 */ - fn push(&mut self, num: i32) { + fn push(&mut self, num: T) { if self.que_size == self.capacity() { println!("队列已满"); return; @@ -53,7 +53,7 @@ impl ArrayQueue { } /* 出队 */ - fn pop(&mut self) -> i32 { + fn pop(&mut self) -> T { let num = self.peek(); // 队首指针向后移动一位,若越过尾部,则返回到数组头部 self.front = (self.front + 1) % self.que_capacity; @@ -62,7 +62,7 @@ impl ArrayQueue { } /* 访问队首元素 */ - fn peek(&self) -> i32 { + fn peek(&self) -> T { if self.is_empty() { panic!("index out of bounds"); } @@ -70,10 +70,10 @@ impl ArrayQueue { } /* 返回数组 */ - fn to_vector(&self) -> Vec { + fn to_vector(&self) -> Vec { let cap = self.que_capacity; let mut j = self.front; - let mut arr = vec![0; self.que_size as usize]; + let mut arr = vec![T::default(); cap as usize]; for i in 0..self.que_size { arr[i as usize] = self.nums[(j % cap) as usize]; j += 1; diff --git a/codes/rust/chapter_stack_and_queue/linkedlist_deque.rs b/codes/rust/chapter_stack_and_queue/linkedlist_deque.rs index 06d026a03..44eacf4d0 100644 --- a/codes/rust/chapter_stack_and_queue/linkedlist_deque.rs +++ b/codes/rust/chapter_stack_and_queue/linkedlist_deque.rs @@ -50,11 +50,11 @@ impl LinkedListDeque { /* 判断双向队列是否为空 */ pub fn is_empty(&self) -> bool { - return self.size() == 0; + return self.que_size == 0; } /* 入队操作 */ - pub fn push(&mut self, num: T, is_front: bool) { + fn push(&mut self, num: T, is_front: bool) { let node = ListNode::new(num); // 队首入队操作 if is_front { @@ -102,7 +102,7 @@ impl LinkedListDeque { } /* 出队操作 */ - pub fn pop(&mut self, is_front: bool) -> Option { + fn pop(&mut self, is_front: bool) -> Option { // 若队列为空,直接返回 None if self.is_empty() { return None; diff --git a/codes/rust/chapter_stack_and_queue/linkedlist_queue.rs b/codes/rust/chapter_stack_and_queue/linkedlist_queue.rs index 50230164d..d35918241 100644 --- a/codes/rust/chapter_stack_and_queue/linkedlist_queue.rs +++ b/codes/rust/chapter_stack_and_queue/linkedlist_queue.rs @@ -33,7 +33,7 @@ impl LinkedListQueue { /* 判断队列是否为空 */ pub fn is_empty(&self) -> bool { - return self.size() == 0; + return self.que_size == 0; } /* 入队 */ diff --git a/codes/rust/chapter_stack_and_queue/linkedlist_stack.rs b/codes/rust/chapter_stack_and_queue/linkedlist_stack.rs index be1415692..7f75586b0 100644 --- a/codes/rust/chapter_stack_and_queue/linkedlist_stack.rs +++ b/codes/rust/chapter_stack_and_queue/linkedlist_stack.rs @@ -58,13 +58,17 @@ impl LinkedListStack { } /* 将 List 转化为 Array 并返回 */ - pub fn to_array(&self, head: Option<&Rc>>>) -> Vec { - if let Some(node) = head { - let mut nums = self.to_array(node.borrow().next.as_ref()); - nums.push(node.borrow().val); - return nums; + pub fn to_array(&self) -> Vec { + fn _to_array(head: Option<&Rc>>>) -> Vec { + if let Some(node) = head { + let mut nums = _to_array(node.borrow().next.as_ref()); + nums.push(node.borrow().val); + return nums; + } + return Vec::new(); } - return Vec::new(); + + _to_array(self.peek()) } } @@ -80,7 +84,7 @@ fn main() { stack.push(5); stack.push(4); print!("栈 stack = "); - print_util::print_array(&stack.to_array(stack.peek())); + print_util::print_array(&stack.to_array()); /* 访问栈顶元素 */ let peek = stack.peek().unwrap().borrow().val; @@ -89,7 +93,7 @@ fn main() { /* 元素出栈 */ let pop = stack.pop().unwrap(); print!("\n出栈元素 pop = {},出栈后 stack = ", pop); - print_util::print_array(&stack.to_array(stack.peek())); + print_util::print_array(&stack.to_array()); /* 获取栈的长度 */ let size = stack.size(); diff --git a/codes/rust/src/include/tree_node.rs b/codes/rust/src/include/tree_node.rs index 3cb37cfc5..8ff354998 100644 --- a/codes/rust/src/include/tree_node.rs +++ b/codes/rust/src/include/tree_node.rs @@ -34,7 +34,7 @@ impl TreeNode { macro_rules! op_vec { ( $( $x:expr ),* ) => { vec![ - $( Option::from($x).map(|x| x) ),* + $(Option::from($x)),* ] }; }