// Copyright 2022 Christian Ulrich // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . // // usage: ./part1 < input pub mod common; use common::Processor; fn main() -> Result<(), &'static str> { let mut processor = Processor::new(); let mut result = 0; for (count, register_x) in processor.cycles().enumerate() { if [20, 60, 100, 140, 180, 220].contains(&(count + 2)) { result += (count + 2) as i64 * register_x?; } } println!("{result}"); Ok(()) }