diff options
| author | nekineki <nekineki@nekineki.net> | 2023-12-01 11:24:45 +0100 |
|---|---|---|
| committer | nekineki <nekineki@nekineki.net> | 2023-12-01 11:24:45 +0100 |
| commit | e4db94d399204655df47cb2edf7d6d3a1b30a2b6 (patch) | |
| tree | b839dc4c52d91f36a67db4dbf47a585599b58707 /2023 | |
| parent | 14baefb6423dd62ec968c518484e02778d31c748 (diff) | |
improve day01
Diffstat (limited to '2023')
| -rw-r--r-- | 2023/day01.rs | 43 |
1 files changed, 17 insertions, 26 deletions
diff --git a/2023/day01.rs b/2023/day01.rs index 3a3bfb2..7db1307 100644 --- a/2023/day01.rs +++ b/2023/day01.rs @@ -5,8 +5,8 @@ use std::fs::File; use std::io::Read; fn main() { - let filename = "in/day01.ref"; - // let filename = "in/day01.pzl"; + // let filename = "in/day01.ref"; + let filename = "in/day01.pzl"; let mut f = File::open(filename).expect("cannot open file"); let mut content = String::new(); @@ -15,41 +15,32 @@ fn main() { // println!("{:?}", lines); let mut res1 = 0; - for line in &lines { - let nums: Vec<_> = line.chars().filter_map(|a| a.to_digit(10)).collect(); - if nums.len() == 1 { - res1 += nums[0] * 10 + nums[0]; - } else { - res1 += nums[0] * 10 + nums[nums.len() - 1]; - } - } - let mut res2 = 0; + let digits = [ "zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", ]; + for line in &lines { - let b: Vec<char> = line.chars().collect(); - let mut nums: Vec<u32> = Vec::new(); - for i in 0..b.len() { - match b[i].to_digit(10) { - Some(i) => nums.push(i), - None => (), + let mut nums1: Vec<u32> = Vec::new(); + let mut nums2: Vec<u32> = Vec::new(); + for (i, c) in line.chars().enumerate() { + if let Some(n) = c.to_digit(10) { + nums1.push(n); + nums2.push(n); } - for (j, digit) in digits.iter().enumerate() { - let d: Vec<char> = digit.chars().collect(); - if d.iter().zip(b[i..].iter()).filter(|&(a, b)| a == b).count() == d.len() { - nums.push(j as u32); + for (d, d_str) in digits.iter().enumerate() { + if line[i..].starts_with(d_str) { + nums2.push(d as u32); } } } - if nums.len() == 0 { - res2 += nums[0] * 10 + nums[0]; - } else { - res2 += nums[0] * 10 + nums[nums.len() - 1]; - } + res1 += nums1[0] * 10 + nums1[nums1.len() - 1]; + res2 += nums2[0] * 10 + nums2[nums2.len() - 1]; } println!("res1: {}", res1); println!("res2: {}", res2); + assert_eq!(res1, 55538); + assert_eq!(res2, 54875); } |
