찾다
백엔드 개발파이썬 튜토리얼코드데이의 출현 : 화장실 리다우트

Advent of Code  Day : Restroom Redoubt

14일차: 로봇 리다우트

솔루션 링크

1부: 로봇 움직임 시뮬레이션 및 안전계수 계산

로봇 움직임 시뮬레이션:
시뮬레이션은 로봇의 초기 위치와 속도를 포함하는 로봇 데이터를 구문 분석하는 것으로 시작됩니다. 각 로봇의 데이터는 튜플(p_x, p_y, v_x, v_y)(x 및 y축을 따른 위치 및 속도 구성요소)로 표시됩니다.

시뮬레이트 기능은 다음 공식을 사용하여 t초 후에 로봇의 새 위치를 계산합니다.

   p_x = (p_x + t * v_x) % width
   p_y = (p_y + t * v_y) % height

이 공식은 로봇의 움직임을 설명하며, 각 시간 단계에서 위치를 업데이트하고 (모듈로 연산으로 인해) 가장자리를 벗어나면 그리드를 둘러쌉니다. 그런 다음 로봇은 업데이트된 위치의 그리드에 다시 배치됩니다.

사분면 계산:
t = 100에서 로봇을 시뮬레이션한 후 코드는 그리드의 4개 사분면 각각에서 로봇 수를 계산합니다. 그리드는 각각 그리드 너비와 높이의 절반으로 계산되는 middle_row_gap과 middle_column_gap을 기준으로 사분면으로 나뉩니다.

100초 후 각 로봇의 위치(x, y)에 대해 프로그램은 로봇이 차지하는 사분면을 확인합니다.

  • 사분면 0: 왼쪽 위
  • 사분면 1: 오른쪽 상단
  • 2사분면: 오른쪽 하단
  • 사분면 3: 왼쪽 하단

그런 다음 Math.prod() 함수를 사용하여 4사분면의 합계를 구합니다.

2부: 크리스마스 트리 패턴 감지

이 작업에 대해 몇 가지 가정을 했습니다. 예를 들어 형성된 이미지는 중앙에 있을 것입니다. 모양을 만들 때 로봇은 모두 함께 응축되어 나무를 형성해야 합니다.

로봇은 예측 가능한 방식으로 움직이며, 로봇의 위치는 시간이 지남에 따라 특정 모양을 형성할 수 있습니다. "크리스마스 트리" 패턴을 감지하기 위해 프로그램은 로봇이 나무 모양과 유사한 촘촘한 형태로 클러스터링되는 시간을 찾습니다. 그리드의 특정 영역에 로봇이 모이는 시점을 찾는 데 초점을 맞춘 접근 방식입니다.

프로그램은 모든 로봇 주위에 큰 경계 상자를 정의하는 것으로 시작됩니다. 이 상자는 시간이 지남에 따라 크기가 점진적으로 줄어듭니다. 시간이 지남에 따라 로봇이 더 작은 영역으로 그룹화된다는 아이디어입니다.

각 시간 단계(로봇의 각 위치)에 대해 프로그램은 이 축소되는 상자 안에 몇 개의 로봇이 있는지 계산합니다. 밀도는 상자 안의 로봇 수를 상자 면적으로 나눈 값입니다. 상자 안에 로봇이 많을수록 밀도가 높아집니다.

밀도가 가장 높은 시간을 추적하는 프로그램입니다. 밀도가 최대일 때 로봇은 가장 촘촘하게 채워져 있어 알아볼 수 있는 모양(크리스마스 트리)을 형성할 가능성이 높습니다.

이것이 작동하는 이유는 무엇입니까?

이 방법은 "크리스마스 트리" 패턴으로 인해 로봇이 그리드의 특정 영역에 클러스터되기 때문에 효과적입니다. 경계 상자를 축소하고 해당 영역의 로봇 밀도를 계산함으로써 프로그램은 로봇이 언제 이 컴팩트한 모양을 형성하는지 식별할 수 있습니다. 밀도가 가장 높다는 것은 로봇이 가장 촘촘하게 그룹화되어 있음을 의미하며 이는 크리스마스 트리 형성에 해당합니다.

따라서 밀도가 가장 높은 시간 단계는 로봇이 크리스마스 트리 패턴을 만드는 때입니다.

언제나처럼 Twitter에서 자유롭게 연락하고 채팅하세요

위 내용은 코드데이의 출현 : 화장실 리다우트의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
파이썬 목록을 어떻게 슬라이스합니까?파이썬 목록을 어떻게 슬라이스합니까?May 02, 2025 am 12:14 AM

slicepaythonlistisdoneusingthesyntaxlist [start : step : step] .here'showitworks : 1) startistheindexofthefirstelementtoinclude.2) stopistheindexofthefirstelemement.3) stepisincrementbetwetweentractionsoftortionsoflists

Numpy Array에서 수행 할 수있는 일반적인 작업은 무엇입니까?Numpy Array에서 수행 할 수있는 일반적인 작업은 무엇입니까?May 02, 2025 am 12:09 AM

NumpyAllowsForVariousOperationsOnArrays : 1) BasicArithmeticLikeadDition, Subtraction, A 및 Division; 2) AdvancedOperationsSuchasmatrixmultiplication; 3) extrayintondsfordatamanipulation; 5) Ag

파이썬으로 데이터 분석에 어레이가 어떻게 사용됩니까?파이썬으로 데이터 분석에 어레이가 어떻게 사용됩니까?May 02, 2025 am 12:09 AM

Arraysinpython, 특히 Stroughnumpyandpandas, areestentialfordataanalysis, setingspeedandefficiency

목록의 메모리 풋 프린트는 파이썬 배열의 메모리 풋 프린트와 어떻게 비교됩니까?목록의 메모리 풋 프린트는 파이썬 배열의 메모리 풋 프린트와 어떻게 비교됩니까?May 02, 2025 am 12:08 AM

ListSandnumpyArraysInpythonHavedifferentmoryfootPrints : ListSaremoreFlexibleButlessMemory-Efficer, whilumpyArraySareOptimizedFornumericalData.1) ListSTorERENFERENCESTOOBJECTS, OverHeadAround64ByTeson64-BitSyStems.2) NumpyArraysTATACONTACOTIGUOU

실행 파이썬 스크립트를 배포 할 때 환경 별 구성을 어떻게 처리합니까?실행 파이썬 스크립트를 배포 할 때 환경 별 구성을 어떻게 처리합니까?May 02, 2025 am 12:07 AM

ToensurePythonScriptTscriptsBecorrectelyRossDevelopment, Staging and Production, UsethesEStrategies : 1) EnvironmberVariblesForsimplesettings, 2) ConfigurationFilesforcomplexSetups 및 3) DynamicLoadingForAdAptability

파이썬 어레이를 어떻게 슬라이스합니까?파이썬 어레이를 어떻게 슬라이스합니까?May 01, 2025 am 12:18 AM

Python List 슬라이싱의 기본 구문은 목록 [start : stop : step]입니다. 1. Start는 첫 번째 요소 인덱스, 2.Stop은 첫 번째 요소 인덱스가 제외되고 3. Step은 요소 사이의 단계 크기를 결정합니다. 슬라이스는 데이터를 추출하는 데 사용될뿐만 아니라 목록을 수정하고 반전시키는 데 사용됩니다.

어떤 상황에서 목록이 배열보다 더 잘 수행 될 수 있습니까?어떤 상황에서 목록이 배열보다 더 잘 수행 될 수 있습니까?May 01, 2025 am 12:06 AM

ListSoutPerformArraysin : 1) DynamicsizingandFrequentInsertions/Deletions, 2) StoringHeterogeneousData 및 3) MemoryEfficiencyForsParsEdata, butMayHavesLightPerformanceCosceperationOperations.

파이썬 어레이를 파이썬 목록으로 어떻게 변환 할 수 있습니까?파이썬 어레이를 파이썬 목록으로 어떻게 변환 할 수 있습니까?May 01, 2025 am 12:05 AM

TOCONVERTAPYTHONARRAYTOALIST, USETHELIST () CONSTUCTORORAGENERATERATOREXPRESSION.1) importTheArrayModuleAndCreateAnarray.2) USELIST (ARR) 또는 [XFORXINARR] TOCONVERTITTOALIST.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.