Skip to content

Commit 2d030f0

Browse files
committed
344. Reverse String (Rust)
1 parent 95be49f commit 2d030f0

File tree

2 files changed

+46
-0
lines changed

2 files changed

+46
-0
lines changed
Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
[package]
2+
name = "_0344_reverse_string"
3+
version = "0.1.0"
4+
edition = "2021"
Lines changed: 42 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,42 @@
1+
pub fn reverse_string(s: &mut Vec<char>) {
2+
if s.len() < 2 {
3+
return;
4+
}
5+
6+
let mut idx = 0;
7+
loop {
8+
let pair_idx = s.len() - idx - 1;
9+
if pair_idx <= idx {
10+
break;
11+
}
12+
13+
let c = s[idx];
14+
s[idx] = s[pair_idx];
15+
s[pair_idx] = c;
16+
idx += 1;
17+
}
18+
}
19+
20+
#[cfg(test)]
21+
mod tests {
22+
#[test]
23+
fn reverse_string() {
24+
struct Case {
25+
input: Vec<char>,
26+
want: Vec<char>,
27+
}
28+
29+
let cases = vec![
30+
Case { input: vec!['h', 'e', 'l', 'l', 'o'], want: vec!['o', 'l', 'l', 'e', 'h'] },
31+
Case { input: vec!['H', 'a', 'n', 'n', 'a', 'h'], want: vec!['h', 'a', 'n', 'n', 'a', 'H'] },
32+
Case { input: vec!['A'], want: vec!['A'] },
33+
Case { input: vec![], want: vec![] },
34+
];
35+
36+
for case in cases.iter() {
37+
let mut got = case.input.clone();
38+
super::reverse_string(&mut got);
39+
assert_eq!(case.want, got);
40+
}
41+
}
42+
}

0 commit comments

Comments
 (0)