day 3 part 1 broken
This commit is contained in:
parent
cfa4a49976
commit
b71ee26fc9
3 changed files with 143 additions and 0 deletions
7
2024/day4/part1/Cargo.lock
generated
Normal file
7
2024/day4/part1/Cargo.lock
generated
Normal file
|
@ -0,0 +1,7 @@
|
|||
# This file is automatically @generated by Cargo.
|
||||
# It is not intended for manual editing.
|
||||
version = 3
|
||||
|
||||
[[package]]
|
||||
name = "part1"
|
||||
version = "0.1.0"
|
6
2024/day4/part1/Cargo.toml
Normal file
6
2024/day4/part1/Cargo.toml
Normal file
|
@ -0,0 +1,6 @@
|
|||
[package]
|
||||
name = "part1"
|
||||
version = "0.1.0"
|
||||
edition = "2021"
|
||||
|
||||
[dependencies]
|
130
2024/day4/part1/src/main.rs
Normal file
130
2024/day4/part1/src/main.rs
Normal file
|
@ -0,0 +1,130 @@
|
|||
use std::fs::read_to_string;
|
||||
|
||||
fn main() {
|
||||
let mut pointcounter = 0;
|
||||
|
||||
let lines: Vec<String> = read_to_string("input.txt")
|
||||
.unwrap()
|
||||
.lines()
|
||||
.map(String::from)
|
||||
.collect();
|
||||
let mut frfrvec: Vec<Vec<char>> = Vec::new();
|
||||
println!("ye the lines are {:?}", lines);
|
||||
|
||||
// make y coord offset by 1
|
||||
let lenxold = lines[1].chars().count();
|
||||
let mut lenvec: Vec<char> = Vec::new();
|
||||
for i in 0..lenxold {
|
||||
lenvec.push('0');
|
||||
}
|
||||
frfrvec.push(lenvec);
|
||||
|
||||
// main section where you push stuff
|
||||
for ministr in lines.clone() {
|
||||
let mut pushvec = Vec::new();
|
||||
pushvec.push('0'); // make x coord offset by 1
|
||||
for minichar in ministr.chars() {
|
||||
pushvec.push(minichar);
|
||||
}
|
||||
frfrvec.push(pushvec);
|
||||
}
|
||||
println!("{:?}", frfrvec);
|
||||
let lenx = lines[1].chars().count();
|
||||
let leny = frfrvec.clone().len();
|
||||
|
||||
for y in 1..leny {
|
||||
let widthup = y - 1 > 4;
|
||||
let widthdown = (leny - y) > 4;
|
||||
|
||||
for x in 1..lenx {
|
||||
// check if enough space left and right
|
||||
println!("x is {x}");
|
||||
println!("y is {y}");
|
||||
println!("width up: {}", widthup);
|
||||
println!("width down: {}", widthdown);
|
||||
let widthleft = x - 1 > 4;
|
||||
println!("width left: {}", widthleft);
|
||||
let widthright = (lenx - x) > 4;
|
||||
println!("width right: {}", widthright);
|
||||
|
||||
// search algorithm starts here
|
||||
// check if the char is s
|
||||
if frfrvec[y][x] == 'X' {
|
||||
// check if going upwards
|
||||
if widthup {
|
||||
if frfrvec[y - 1][x] == 'M'
|
||||
&& frfrvec[y - 2][x] == 'A'
|
||||
&& frfrvec[y - 3][x] == 'S'
|
||||
{
|
||||
pointcounter += 1;
|
||||
}
|
||||
}
|
||||
// check if going diag up left
|
||||
if widthup && widthleft {
|
||||
if frfrvec[y - 1][x - 1] == 'M'
|
||||
&& frfrvec[y - 2][x - 2] == 'A'
|
||||
&& frfrvec[y - 3][x - 3] == 'S'
|
||||
{
|
||||
pointcounter += 1;
|
||||
}
|
||||
}
|
||||
// check if going left
|
||||
if widthleft {
|
||||
if frfrvec[y][x - 1] == 'M'
|
||||
&& frfrvec[y][x - 2] == 'A'
|
||||
&& frfrvec[y][x - 3] == 'S'
|
||||
{
|
||||
pointcounter += 1;
|
||||
}
|
||||
}
|
||||
// check if going diag down left
|
||||
if widthdown && widthleft {
|
||||
if frfrvec[y + 1][x - 1] == 'M'
|
||||
&& frfrvec[y + 2][x - 2] == 'A'
|
||||
&& frfrvec[y + 3][x - 3] == 'S'
|
||||
{
|
||||
pointcounter += 1;
|
||||
}
|
||||
}
|
||||
// check if going down
|
||||
if widthdown {
|
||||
if frfrvec[y + 1][x] == 'M'
|
||||
&& frfrvec[y + 2][x] == 'A'
|
||||
&& frfrvec[y + 3][x] == 'S'
|
||||
{
|
||||
pointcounter += 1;
|
||||
}
|
||||
}
|
||||
// check if going diag down right
|
||||
if widthdown && widthright {
|
||||
if frfrvec[y + 1][x + 1] == 'M'
|
||||
&& frfrvec[y + 2][x + 2] == 'A'
|
||||
&& frfrvec[y + 3][x + 3] == 'S'
|
||||
{
|
||||
pointcounter += 1;
|
||||
}
|
||||
}
|
||||
// check if going right
|
||||
if widthright {
|
||||
if frfrvec[y][x + 1] == 'M'
|
||||
&& frfrvec[y][x + 2] == 'A'
|
||||
&& frfrvec[y][x + 3] == 'S'
|
||||
{
|
||||
pointcounter += 1;
|
||||
}
|
||||
}
|
||||
// check if going diag right up
|
||||
if widthright && widthup {
|
||||
if frfrvec[y - 1][x + 1] == 'M'
|
||||
&& frfrvec[y - 2][x + 2] == 'A'
|
||||
&& frfrvec[y - 3][x + 3] == 'S'
|
||||
{
|
||||
pointcounter += 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
println!("{pointcounter}");
|
||||
}
|
Loading…
Add table
Reference in a new issue