首頁 後端開發 Python教學 代碼日的到來:廁所堡壘

代碼日的到來:廁所堡壘

Dec 27, 2024 am 11:31 AM

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 處模擬機器人後,程式碼計算網格四個像限中每個象限中的機器人數量。網格根據 middle_row_gap 和 middle_column_gap 劃分為象限,分別計算為網格寬度和高度的一半。

對於 100 秒後每個機器人的位置 (x, y),程式檢查機器人佔據哪個象限:

  • 象限 0:左上角
  • 象限 1:右上角
  • 象限 2:右下
  • 象限 3:左下

然後我們使用 Math.prod() 函數得到 4 象限總數的乘積。

第 2 部分:偵測聖誕樹圖案

我對此任務做了一些假設,例如形成的圖像將位於中間/集中。當機器人形成形狀時,它們必須全部凝聚在一起 - 形成樹。

機器人以可預測的方式移動,並且它們的位置可以隨著時間的推移形成特定的形狀。為了偵測「聖誕樹」模式,程式會尋找機器人聚集成類似樹形狀的緊密隊形的時間。該方法的重點是發現機器人何時聚集在網格的特定區域。

程式首先在所有機器人周圍定義一個大邊界框。隨著時間的推移,這個盒子的尺寸逐漸減少。這個想法是,隨著時間的推移,機器人將聚集成一個較小的區域。

對於每個時間步長(機器人的每個位置),程式會計算這個縮小的盒子內有多少機器人。它測量密度,即盒子內機器人的數量除以盒子麵積。盒子裡的機器人越多,密度就越高。

程式會追蹤密度最高的時間。當密度最大時,機器人排列得最緊密,這很可能是在它們形成可識別的形狀(聖誕樹)時發生的。

為什麼這有效?

這個方法之所以有效,是因為「聖誕樹」模式會導致機器人聚集在網格的特定區域。透過縮小邊界框並計算該區域中機器人的密度,程式可以識別機器人何時形成這種緊湊的形狀。密度最高表示機器人的分組最緊密,對應聖誕樹的排列。

因此,密度最高的時間步是機器人創造聖誕樹圖案的時間。

一如既往,隨時在 Twitter 上聯繫和聊天

以上是代碼日的到來:廁所堡壘的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1657
14
CakePHP 教程
1415
52
Laravel 教程
1309
25
PHP教程
1257
29
C# 教程
1230
24
Python vs.C:申請和用例 Python vs.C:申請和用例 Apr 12, 2025 am 12:01 AM

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

Python:遊戲,Guis等 Python:遊戲,Guis等 Apr 13, 2025 am 12:14 AM

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

您可以在2小時內學到多少python? 您可以在2小時內學到多少python? Apr 09, 2025 pm 04:33 PM

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

2小時的Python計劃:一種現實的方法 2小時的Python計劃:一種現實的方法 Apr 11, 2025 am 12:04 AM

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python與C:學習曲線和易用性 Python與C:學習曲線和易用性 Apr 19, 2025 am 12:20 AM

Python更易學且易用,C 則更強大但複雜。 1.Python語法簡潔,適合初學者,動態類型和自動內存管理使其易用,但可能導致運行時錯誤。 2.C 提供低級控制和高級特性,適合高性能應用,但學習門檻高,需手動管理內存和類型安全。

Python:探索其主要應用程序 Python:探索其主要應用程序 Apr 10, 2025 am 09:41 AM

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

Python和時間:充分利用您的學習時間 Python和時間:充分利用您的學習時間 Apr 14, 2025 am 12:02 AM

要在有限的時間內最大化學習Python的效率,可以使用Python的datetime、time和schedule模塊。 1.datetime模塊用於記錄和規劃學習時間。 2.time模塊幫助設置學習和休息時間。 3.schedule模塊自動化安排每週學習任務。

Python:自動化,腳本和任務管理 Python:自動化,腳本和任務管理 Apr 16, 2025 am 12:14 AM

Python在自動化、腳本編寫和任務管理中表現出色。 1)自動化:通過標準庫如os、shutil實現文件備份。 2)腳本編寫:使用psutil庫監控系統資源。 3)任務管理:利用schedule庫調度任務。 Python的易用性和豐富庫支持使其在這些領域中成為首選工具。

See all articles