From 149158fca544e4050ed4f70e2a44a0c16d1e747c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?i=C3=B1aki=20llorens?= Date: Tue, 27 Aug 2024 12:50:14 -0300 Subject: [PATCH] Replace double for in 'neighbour_positions' for NEIGHBOUR_OFFSETS --- src/cell.rs | 34 ++++++++++++++++++---------------- 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/src/cell.rs b/src/cell.rs index ab80cdb..ae52532 100644 --- a/src/cell.rs +++ b/src/cell.rs @@ -1,3 +1,14 @@ +const NEIGHBOUR_OFFSETS: [(i32, i32); 8] = [ + (-1, -1), + (-1, 0), + (-1, 1), + (0, -1), + (0, 1), + (1, -1), + (1, 0), + (1, 1), +]; + /// Represents a cell of the Game of Life. #[derive(Clone, Eq, PartialEq, Hash, Debug)] pub struct Cell { @@ -13,22 +24,13 @@ impl Cell { // Returns the positions of the 8 neighbours of a cell. pub fn neighbour_positions(&self) -> Vec { - let mut positions = Vec::with_capacity(8); - - for dx in -1..=1 { - for dy in -1..=1 { - if dx == 0 && dy == 0 { - continue; - } - - positions.push(Cell { - x: self.x + dx, - y: self.y + dy, - }); - } - } - - positions + NEIGHBOUR_OFFSETS + .iter() + .map(|&(dx, dy)| Cell { + x: self.x + dx, + y: self.y + dy, + }) + .collect() } /// Returns the position of the cell as a tuple.