Hello,
I am trying to solve the day 7 using Rust and this is what I came up with so far:
use std::fs;
fn calculate(answer: &i32, numbers: &mut Vec<i32>) -> bool {
if numbers.len() >= 2 {
let tmp1 = numbers[0];
let tmp2 = numbers[1];
numbers.remove(0);
numbers.remove(0);
numbers.insert(0, tmp1 * tmp2);
if calculate(answer, numbers) == true {
return true;
} else {
numbers.remove(0);
numbers.insert(0, tmp1 + tmp2);
if calculate(answer, numbers) == true {
return true;
} else {
return false;
}
}
} else {
if *answer == numbers[0] {
println!("> {} true", numbers[0]);
return true;
} else {
println!("> {} false", numbers[0]);
return false;
}
}
}
fn main() {
let contents = fs::read_to_string("sample.txt")
.expect("Should have been able to read the file");
for line in contents.lines() {
let tmp = line.split(":").collect::<Vec<&str>>();
let answer = tmp[0].to_string().parse::<i32>().unwrap();
println!("{:?}", answer);
let numbers_str = tmp[1].split(" ");
let mut numbers: Vec<i32> = Vec::new();
for num in numbers_str {
if num.len() == 0 {
continue;
}
numbers.push(num.parse::<i32>().unwrap());
}
println!("{:?}", numbers);
if calculate(&answer, &mut numbers) == true {
println!("it's true");
}
}
}
I don’t know why the recursion is not working. any help would be appreciated.
Excellent, thats what I suspected. That presumably involves a lot of
numbers.clone()
right?In my solution, I passed the first number by value, and the remaining N numbers as a slice to avoid that. The original vec doesn’t get mutated, and I beleive there are no clones/copy’s.
Doesn’t really matter for this challenge though.