Compare commits
7 Commits
64d4c9dfdd
...
main
Author | SHA1 | Date | |
---|---|---|---|
708d5b317e | |||
bcad961d8d | |||
beefa83b7c | |||
dadbc79893 | |||
8c81c2032e | |||
44e5a16b48 | |||
422c1a4124 |
2
LICENSE
2
LICENSE
@ -1,6 +1,6 @@
|
||||
MIT License
|
||||
|
||||
Copyright (c) <year> <copyright holders>
|
||||
Copyright (c) 2022 niku
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||
|
||||
|
8
aoc2022/Cargo.toml
Normal file
8
aoc2022/Cargo.toml
Normal file
@ -0,0 +1,8 @@
|
||||
[package]
|
||||
name = "aoc2022"
|
||||
version = "0.1.0"
|
||||
edition = "2021"
|
||||
|
||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||
|
||||
[dependencies]
|
2250
aoc2022/inputs/day_1.txt
Normal file
2250
aoc2022/inputs/day_1.txt
Normal file
File diff suppressed because it is too large
Load Diff
2500
aoc2022/inputs/day_2.txt
Normal file
2500
aoc2022/inputs/day_2.txt
Normal file
File diff suppressed because it is too large
Load Diff
1000
aoc2022/inputs/day_4.txt
Normal file
1000
aoc2022/inputs/day_4.txt
Normal file
File diff suppressed because it is too large
Load Diff
1
aoc2022/inputs/day_6.txt
Normal file
1
aoc2022/inputs/day_6.txt
Normal file
@ -0,0 +1 @@
|
||||
pnnfhnhshrhmhwwmwzmznmnwmwfmfhfjfcjjtgtbggpdgdjjbjrjsjpjrrmddmgmpmddrhddnfnfzfpfvpfpprhhlffmtffqhhdtdcdsswsdwswmmfvvpdprrnnhhhtffnfbbznbznnvdnnbffjrfrbfrbrgbrrntnggrqqwtqwwgjgsswgwqwtwwsvwvbwvwrwlrlppzfzwfzzpmzzhqqzqlzlglzzmrmwrmwwvmwvvnppjfjttlffhjjjsccbggnffqgfgjjnccmdmzmllvnlnznttlvlttvnvgnvvqvmvqqzrqqcgglzzwtztwwmjmzjjnddsffqrqlrrvsvdvldvvlgvlvccdzczcqcpphggtnthhhtbhtttcjtjcjgcjcbbrhbbfrffgjgdgzddcttczzsccbpcpddcpcggmjgjddtcccthccfrccmdmhmddnwddfldffntnptnpttcptcptpfphhmfmwfwmmlblgbgvbvlltqltldttfcfcclgcllmplmlbbjnjzjnzzttnvvgddshddsqddggsqgqddsggdhghjgjhhgchhdmdjmjddgdhghrrphrrpnnqhhjwwqrrcmmslmmszzpgzpzzrmzmznzllnjnnlnbbdvdsdffbpffcmmnznqqcbbzvvjnjvvwqwgqqpnnzwnzwnzwwwlpwpzzfqzfqqwnqnbnfnqnbqqbggqnqdndrrzzlffbbgqgfgrfrqqsddnqnqjjgssqwqwcqcpcrrqppwpjjfnfpffhphwwmcwwznwznnplptlplnlsnlsldslslsffwtwftwtbtdbbjsjcczwwfllwtlwtlwlvwlwrwppsggvcvrrqcrqqvmqvmmbrrsbsfspspjpnnmpmqmcczgzffqmfmtmpppwzppzrpzrzsrrpqrpqpmpvmpvpttbqtqmtmjttqdqgggcppclcjcpcsppctpplpdpcppcmmdzmzddvhvhnhrrldllcwwbnwnssshlhrhthggtmggbjbjwwbvbttjllvrrfggngvngnmmvzzrrmddmcddztztctfccqpcpcqqvqppqcqdcdhhvhssgfgzgwwzmmnssvwwbqbhbnhnphpqqjcqcddfwfttqjtqtlttglljgjbgjgnnsqqvrvffqvqfqbffljjpffssqdsqstqqqldqqmhmsmsqqwtqwqdqgdgjjfbjffgbbrhhqghgppqgpgmpmmfzfhhfrhffgmfggpzgpzzhtzhhlbhhqbbzvvnvqnntptmmbhbdhdwwmjjcnnmsscqcbbtjtvjvwjvvmsmjmtmpmgghttcztzggpddbfbfgbbdsdrsrrqfqjjqfjjhzhtzzmdzzcgzgdzzmvmmfmjmgjmggmppbdppmzpppvfppzhhfsfwfhhpjpmmrjjpssdccjpjpwjppvdpphcpcjcfjfwjfwfjwfjjqcqcwqqqsmmmbbgdgwwpcwwdfdlflrltlgtthfhfjhhlthtddlgdggsjsrrdpdcppgttphpgpwppmpzmmrjmmvjvgvgfglfgllbqlqhllszzlwwhzzdfdcdtctptwtztfzzmjzjtjtrjrcrnrjjmwmnnbddgvgtgsstjsszmpqdmzgqflrbrspjmtzjcrmlzltmhgblghnwqvwwqwzbpnfrpdpblpjgshfccfbjfsnwvvhnjftsdnsgtzzjtzpmtfdvzrhtqpblhwgmqtgpbfvbdmsnrrrvvbstpsznvbbwgjfqjrhdvwvgptpglpfddhddmtglmjlpwlvfpbtbmgbplbzrlpdlvqzcwhbscpszgfstjpfdvfpmljlngrbgrdnnblzqrfpzsdvblpwbtnhdjclldvwvbwcwzfzbdspgwpfqjfbdbrqcshtlvcrdstnzggbwqnzbrfzbpnrtmvpbvdhcvdsdshgtvhfgdzljflppqbwclnvbhbczvrscjhlbgbfvwdjhnjsgmvwhpfgwbbmnndpnglfrmtfdzvqgfjdqfhgrhvpbqndmqnqccgwswwdsqjnbjtjbjdbqgjnmfbdvlnfwbnrdqgvgzzhmmbbdzfdvvpwhpbwbnzdcdpchrwlhfsjnhhjggvplmqggwjdsvjtpnpnqgldjjdcscrdltssjdrpcrfbgbcjfplhzgwbprfcslhpcngtszrghmwhzdqscbfrhzdwcffzvmjrmcjcstfvhplvrsglgsjnjtrpddsdfqjsndjnfmvdhfgdbzzflqhsrrwmrnlpqzmcddqbqvvzgtlztpgjnddtcnbmqsjlhmcszrmcjvwzpptlfqsmpvgnzvrjdwzpdwqgbmdgdtvjlmfczthjbcgfhbqpnmlbmrwwhfptzlbmfdhssznjcvjbmnjtnvzjhzczlrrdnttmmcbnzhqpplzqwgttwrnwfvmnptgqlfrnzvqpjfgrzwmlcwvtptvcvrlsrdwdgqfvffspmdbnnrqjttpqvhvdpbcrvzptwnhhfsqzchmncvttcdgdnlppcfzpmjpvbvqhlvplwvrmmbbggbwttwmvsqjlllsftprsmtmnzjcqfzblrllzgshfljchrjwjlpvhpbrtrsschzltrblgjnbgdnmwdggjhqggntblnhsvfgsbcblhmctbqzqwmhqnjhpzjfqpjdgwpzhczcftfcpdhvzhzccmwmrfrbqshzmtpqgpbbvfqqbjbmvnlnlwjtzrpmhdlffccrqcfgsjfszbrzrfztntchtmgmbhjgmlsqzcbtqqjzzlghtzzqmlnnvsgsvbbjfgqsqbqmqrdzwpwdgbggpdvhvnlzshhntprjdwhnwfvdjzpqgflwrvwgtmfdmfdztcbtfnjdrvgdwwczdgphnvdgrbdchprqldfjrvcsflcmlcmzqvqgsgnzcgmrhccgcmptcdzhbcdgdtppwztfstzqqzqrdzlnzthggjmpcflmbcmdrrjnnpbpqfmjbzqbtsjjgdlmgncbmgspqqvbrvzrdjscpzjsdtcdvsdwqlmwrngttswnrsbqctvhgfnnwblpcqzdmzpfchplslspmghvgcqntmlrfhgpcbpspvfhnvqvglsqzsnsdzddqpbsjhlclslngbwvvgjhwfcncqsmqwbptzvpzlzslsjjjldjpwpfrdlfbjphqcjtsgqdsdfdjhqgdhcppndwmhmmldvvmblcqcqfqhltbcbvrnghjfmtgqwtwljtczvqlnmgscjhqdhnzwhzvzzqnlsrhqvljqpgpwghfqlhjjrrhvnmnnrbnlhdcjctwtlhmhhmhjvcgzdrzmdjrvqzgnsttjdwglgwlcmbcdnjprgfsbbdzzngbqdrvwwwhbtlnnmzqdjttsrrpvlfdqnfhhtdtvmpcjgdwtbnqmwmtszdqfmbhjsjpqqddzfggwjhbtlnqfgcwbjzdtcpcpzgnrmnvwlpgmwfjlpgppdfrfvvjwsfcdqdnpcpjbqsvhttssgptqjghctrbgntlfjzdrfjccsprsjlrrwrzsmnjsqslmpdtrvhlqbnmgpjthpqdqmnvrtzlhhzzfzbrcclpmpcszhbttgrtcpgcpjwpdbfpfvgspsgtvglwthqcmcvmrfmclwlvjlsptfgmtlrnsvjrnfwzhdcsmgztpzfcvzwdztpppvqpvqfpdrsfnlhrbqwrsqjtwjmhnpwmqmpdgdhbtbpfwnmswffdqffdggrdrpmngvpzplmmwlddnhcvjjzqqfsbbtfmzdwnpvbjrshmllczhgvwwcbcbtfrfnplqjwmjlvpwwgfrtffwddwppsgtnlmpvfnhfzcsgjbqbjmbvpnqppsrvwnlzvcmjqgtbzrdsnrgwbfmrvnflgccrssfvcwgllqqbbcthzmbtnsmbzbcczhtzcvmthttpltrtdmgspctvtpvqbhmnnpnjwmhpqclmjsdrbjwvjbtzcjlqbjsvbgdwqzflnwzcfjwtrhjgfshfmwbjfwpnhjsmtpgbpwlfjjnmdlrhchmnfmgmgcrftmwbzshdwbhndgwtjbrrvbwprqppfmgfmfllpcjgrwdmtzddthsjlgjljv
|
41
aoc2022/src/day_1.rs
Normal file
41
aoc2022/src/day_1.rs
Normal file
@ -0,0 +1,41 @@
|
||||
fn solution_part1(text: String) -> i32 {
|
||||
text.split("\n\n")
|
||||
.map(|e| e.lines().map(|c| c.parse::<i32>().unwrap()).sum())
|
||||
.max()
|
||||
.unwrap()
|
||||
}
|
||||
|
||||
fn solution_part2(text: String) -> i32 {
|
||||
let mut cals = text
|
||||
.split("\n\n")
|
||||
.map(|e| e.lines().map(|c| c.parse::<i32>().unwrap()).sum())
|
||||
.collect::<Vec<i32>>();
|
||||
cals.sort();
|
||||
return cals.iter().rev().take(3).sum();
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use std::fs;
|
||||
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn basic_example() {
|
||||
let input =
|
||||
"1000\n2000\n3000\n\n4000\n\n5000\n6000\n\n7000\n8000\n9000\n\n10000".to_string();
|
||||
assert_eq!(solution_part1(input), 24000);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn answer_part1() {
|
||||
let input = fs::read_to_string("inputs/day_1.txt").unwrap();
|
||||
println!("Answer to part 1 of day 1: {:#?}", solution_part1(input));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn answer_part2() {
|
||||
let input = fs::read_to_string("inputs/day_1.txt").unwrap();
|
||||
println!("Answer to part 2 of day 1: {:#?}", solution_part2(input));
|
||||
}
|
||||
}
|
68
aoc2022/src/day_2.rs
Normal file
68
aoc2022/src/day_2.rs
Normal file
@ -0,0 +1,68 @@
|
||||
fn calc_score(opponent: char, me: char) -> u32 {
|
||||
let mut score = 0;
|
||||
score += match (opponent, me) {
|
||||
('A', 'Z') | ('B', 'X') | ('C', 'Y') => 0,
|
||||
('C', 'X') | ('A', 'Y') | ('B', 'Z') => 6,
|
||||
_ => 3,
|
||||
};
|
||||
|
||||
score += match me {
|
||||
'X' => 1,
|
||||
'Y' => 2,
|
||||
'Z' => 3,
|
||||
_ => unreachable!(),
|
||||
};
|
||||
|
||||
return score;
|
||||
}
|
||||
|
||||
fn find_move(opponent: char, result: char) -> char {
|
||||
match (opponent, result) {
|
||||
(_, 'Y') => char::from_u32(opponent as u32 - 'A' as u32 + 'X' as u32).unwrap(),
|
||||
('B', 'X') | ('C', 'Z') => 'X',
|
||||
('C', 'X') | ('A', 'Z') => 'Y',
|
||||
('A', 'X') | ('B', 'Z') => 'Z',
|
||||
_ => unreachable!(),
|
||||
}
|
||||
}
|
||||
|
||||
fn solution_part1(text: String) -> u32 {
|
||||
text.lines()
|
||||
.filter(|g| g.len() == 3)
|
||||
.map(|g| {
|
||||
let mut chars = g.chars();
|
||||
calc_score(chars.next().unwrap(), chars.next_back().unwrap())
|
||||
})
|
||||
.sum()
|
||||
}
|
||||
|
||||
fn solution_part2(text: String) -> u32 {
|
||||
text.lines()
|
||||
.filter(|g| g.len() == 3)
|
||||
.map(|g| {
|
||||
let mut chars = g.chars();
|
||||
let opponent = chars.next().unwrap();
|
||||
let me = find_move(opponent, chars.next_back().unwrap());
|
||||
calc_score(opponent, me)
|
||||
})
|
||||
.sum()
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use std::fs;
|
||||
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn answer_part1() {
|
||||
let input = fs::read_to_string("inputs/day_2.txt").unwrap();
|
||||
println!("Answer to part 1 of day 2: {:#?}", solution_part1(input));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn answer_part2() {
|
||||
let input = fs::read_to_string("inputs/day_2.txt").unwrap();
|
||||
println!("Answer to part 2 of day 2: {:#?}", solution_part2(input));
|
||||
}
|
||||
}
|
72
aoc2022/src/day_4.rs
Normal file
72
aoc2022/src/day_4.rs
Normal file
@ -0,0 +1,72 @@
|
||||
#[derive(Debug)]
|
||||
struct Range(i32, i32);
|
||||
|
||||
impl Range {
|
||||
fn contains(&self, other: &Range) -> bool {
|
||||
return self.0 <= other.0 && self.1 >= other.1;
|
||||
}
|
||||
|
||||
fn from_str(string: &str) -> Range {
|
||||
let (start, end) = string.split_once('-').unwrap();
|
||||
return Range(start.parse::<i32>().unwrap(), end.parse::<i32>().unwrap());
|
||||
}
|
||||
}
|
||||
|
||||
fn parse_pairs(line: &str) -> (Range, Range) {
|
||||
let (left, right) = line.split_once(',').unwrap();
|
||||
return (Range::from_str(left), Range::from_str(right));
|
||||
}
|
||||
|
||||
fn solution_part1(input: String) -> i32 {
|
||||
let mut result: i32 = 0;
|
||||
for line in input.lines() {
|
||||
let (left, right) = parse_pairs(line);
|
||||
if left.contains(&right) || right.contains(&left) {
|
||||
result += 1;
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
fn solution_part2(input: String) -> i32 {
|
||||
let mut result: i32 = 0;
|
||||
for line in input.lines() {
|
||||
let (left, right) = parse_pairs(line);
|
||||
if left.0 <= right.1 && left.1 >= right.0 {
|
||||
result += 1;
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use std::fs;
|
||||
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn contains() {
|
||||
assert!(Range(4, 6).contains(&Range(6, 6)))
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn basic_example() {
|
||||
let input = "2-4,6-8\n2-3,4-5\n5-7,7-9\n2-8,3-7\n6-6,4-6\n2-6,4-8".to_string();
|
||||
let expected = 2;
|
||||
let result = solution_part1(input);
|
||||
assert_eq!(result, expected);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn answer_part1() {
|
||||
let input = fs::read_to_string("inputs/day_4.txt").unwrap();
|
||||
println!("Answer to part 1 of day 4: {:#?}", solution_part1(input));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn answer_part2() {
|
||||
let input = fs::read_to_string("inputs/day_4.txt").unwrap();
|
||||
println!("Answer to part 2 of day 4: {:#?}", solution_part2(input));
|
||||
}
|
||||
}
|
49
aoc2022/src/day_6.rs
Normal file
49
aoc2022/src/day_6.rs
Normal file
@ -0,0 +1,49 @@
|
||||
use std::collections::HashSet;
|
||||
|
||||
fn is_unique_string(chars: &str) -> bool {
|
||||
let mut set: HashSet<char> = HashSet::with_capacity(chars.len());
|
||||
set.extend(chars.chars());
|
||||
return set.len() == chars.len();
|
||||
}
|
||||
|
||||
fn solution(sequence: String, sub_len: usize) -> usize {
|
||||
for i in 0..(sequence.len() - sub_len) {
|
||||
let sub = &sequence[i..i + sub_len];
|
||||
if is_unique_string(sub.try_into().unwrap()) {
|
||||
return i + sub_len;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use std::fs;
|
||||
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn basic_example() {
|
||||
let input = "bvwbjplbgvbhsrlpgdmjqwftvncz".to_string();
|
||||
assert_eq!(solution(input, 4), 5);
|
||||
let input = "nppdvjthqldpwncqszvftbrmjlhg".to_string();
|
||||
assert_eq!(solution(input, 4), 6);
|
||||
let input = "nznrnfrfntjfmvfwmzdfjlvtqnbhcprsg".to_string();
|
||||
assert_eq!(solution(input, 4), 10);
|
||||
let input = "zcfzfwzzqfrljwzlrfnpqdbhtmscgvjw".to_string();
|
||||
assert_eq!(solution(input, 4), 11);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn answer_part1() {
|
||||
let input = fs::read_to_string("inputs/day_6.txt").unwrap();
|
||||
println!("Answer to part 1 of day 6: {:#?}", solution(input, 4));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn answer_part2() {
|
||||
let input = fs::read_to_string("inputs/day_6.txt").unwrap();
|
||||
println!("Answer to part 2 of day 6: {:#?}", solution(input, 14));
|
||||
}
|
||||
}
|
5
aoc2022/src/lib.rs
Normal file
5
aoc2022/src/lib.rs
Normal file
@ -0,0 +1,5 @@
|
||||
#![allow(dead_code)]
|
||||
mod day_1;
|
||||
mod day_2;
|
||||
mod day_4;
|
||||
mod day_6;
|
Reference in New Issue
Block a user