2024 - Day 4 part 2
This commit is contained in:
		
							parent
							
								
									7463f0f9db
								
							
						
					
					
						commit
						d1e7ff9785
					
				
					 1 changed files with 45 additions and 0 deletions
				
			
		
							
								
								
									
										45
									
								
								2024/4/4_2.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								2024/4/4_2.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,45 @@ | ||||||
|  | #!/usr/bin/env python | ||||||
|  | # 2024 - Advent Of Code 4 - part 2 | ||||||
|  | 
 | ||||||
|  | # file = 'input_example.txt' | ||||||
|  | file = 'input.txt' | ||||||
|  | 
 | ||||||
|  | # pylint: disable=consider-using-with | ||||||
|  | input_lines = [line.strip('\n') for line in open(file, encoding="utf-8")] | ||||||
|  | 
 | ||||||
|  | MAX_X = len(input_lines[0]) | ||||||
|  | MAX_Y = len(input_lines) | ||||||
|  | 
 | ||||||
|  | # for line in input_lines: | ||||||
|  | #     print(f'{line}') | ||||||
|  | 
 | ||||||
|  | def find_xmas(grid, start_pos): | ||||||
|  |     x = start_pos[0] | ||||||
|  |     y = start_pos[1] | ||||||
|  | 
 | ||||||
|  |     if grid[y - 1][x - 1] == 'M' and grid[y - 1][x + 1] == 'M': | ||||||
|  |         if grid[y + 1][x - 1] == 'S' and grid[y + 1][x + 1] == 'S': | ||||||
|  |             return True | ||||||
|  | 
 | ||||||
|  |     if grid[y - 1][x - 1] == 'M' and grid[y + 1][x - 1] == 'M': | ||||||
|  |         if grid[y - 1][x + 1] == 'S' and grid[y + 1][x + 1] == 'S': | ||||||
|  |             return True | ||||||
|  | 
 | ||||||
|  |     if grid[y - 1][x + 1] == 'M' and grid[y + 1][x + 1] == 'M': | ||||||
|  |         if grid[y - 1][x - 1] == 'S' and grid[y + 1][x - 1] == 'S': | ||||||
|  |             return True | ||||||
|  | 
 | ||||||
|  |     if grid[y + 1][x - 1] == 'M' and grid[y + 1][x + 1] == 'M': | ||||||
|  |         if grid[y - 1][x - 1] == 'S' and grid[y - 1][x + 1] == 'S': | ||||||
|  |             return True | ||||||
|  | 
 | ||||||
|  |     return False | ||||||
|  | 
 | ||||||
|  | accum = 0 | ||||||
|  | for pos_y in range(1, MAX_Y - 1): | ||||||
|  |     for pos_x in range(1, MAX_X - 1): | ||||||
|  |         if input_lines[pos_y][pos_x] == 'A': | ||||||
|  |             if find_xmas(input_lines, (pos_x, pos_y)): | ||||||
|  |                 accum += 1 | ||||||
|  | 
 | ||||||
|  | print(f'{accum=}') | ||||||
		Loading…
	
		Reference in a new issue