1
0
Fork 0

Compare commits

...

3 Commits

Author SHA1 Message Date
Pcornat befbc009cc
4th problem part 1 done ! 2022-12-08 22:08:01 +01:00
Pcornat 83c16d7fb7
Personnal profile (release) 2022-12-08 22:07:50 +01:00
Pcornat aee8ae9a4f
getting rid of useless file 2022-12-08 22:07:36 +01:00
5 changed files with 66 additions and 9 deletions

16
.gitignore vendored
View File

@ -1,2 +1,16 @@
/target
.idea
.idea
# Generated by Cargo
# will have compiled files and executables
debug/
target/
# Remove Cargo.lock from gitignore if creating an executable, leave it for libraries
# More information here https://doc.rust-lang.org/cargo/guide/cargo-toml-vs-cargo-lock.html
Cargo.lock
# These are backup files generated by rustfmt
**/*.rs.bk
# MSVC Windows builds of rustc generate these, which store debugging information
*.pdb

7
Cargo.lock generated
View File

@ -1,7 +0,0 @@
# This file is automatically @generated by Cargo.
# It is not intended for manual editing.
version = 3
[[package]]
name = "advent_of_code"
version = "0.1.0"

View File

@ -5,4 +5,9 @@ edition = "2021"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[profile.release-perso]
inherits = "release"
incremental = true
rpath = true
[dependencies]

View File

@ -1,4 +1,4 @@
use advent_of_code::{prob1, prob2, prob3};
use advent_of_code::{prob1, prob2, prob3, prob4};
fn main() {
{
@ -23,4 +23,9 @@ fn main() {
let max_part2 = prob3::solve_part2(file_path);
println!("Solution for problem 3 part 2: {max_part2}");
}
{
let file_path = "prob4_part1.txt";
let max_part1 = prob4::solve_part1(file_path);
println!("Solution for problem 4 part 1: {max_part1}");
}
}

View File

@ -0,0 +1,40 @@
fn mutual_inclusion(first_pair: &[u32], second_pair: &[u32]) -> bool {
(first_pair[0] <= second_pair[0] && first_pair[1] >= second_pair[1])
|| (second_pair[0] <= first_pair[0] && second_pair[1] >= first_pair[1])
}
pub fn solve_part1(file_path: &str) -> i32 {
let result = std::fs::read_to_string(file_path)
.expect("Please provide a text file as an argument.")
.lines()
.map(|line| {
let tmp = line.split(',').collect::<Vec<&str>>();
let firs_pair = tmp
.first()
.expect("First character error")
.split('-')
.map(|first_split| {
first_split
.parse::<u32>()
.expect("Parsing number in first pair failed")
})
.collect::<Vec<u32>>();
let second_pair = tmp
.last()
.expect("First character error")
.split('-')
.map(|first_split| {
first_split
.parse::<u32>()
.expect("Parsing number in first pair failed")
})
.collect::<Vec<u32>>();
if mutual_inclusion(&firs_pair, &second_pair) {
1
} else {
0
}
})
.collect::<Vec<i32>>();
result.iter().sum()
}