検索

Advent of Code  Day : Restroom Redoubt

14日目:ロボット要塞

ソリューションへのリンク

パート 1: ロボットの動作のシミュレーションと安全率の計算

ロボットの動きのシミュレーション:
シミュレーションは、ロボットの初期位置と速度を含むロボット データを解析することから始まります。各ロボットのデータは、x 軸と y 軸に沿った位置と速度の要素であるタプル (p_x、p_y、v_x、v_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 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Pythonリストをどのようにスライスしますか?Pythonリストをどのようにスライスしますか?May 02, 2025 am 12:14 AM

slicingapythonlistisdoneusingtheyntaxlist [start:stop:step] .hore'showitworks:1)startisthe indexofthefirstelementtoinclude.2)spotisthe indexofthefirmenttoeexclude.3)staptistheincrementbetbetinelements

Numpyアレイで実行できる一般的な操作は何ですか?Numpyアレイで実行できる一般的な操作は何ですか?May 02, 2025 am 12:09 AM

numpyallows forvariousoperationsonarrays:1)basicarithmeticlikeaddition、減算、乗算、および分割; 2)AdvancedperationssuchasmatrixMultiplication;

Pythonを使用したデータ分析では、配列はどのように使用されていますか?Pythonを使用したデータ分析では、配列はどのように使用されていますか?May 02, 2025 am 12:09 AM

Arraysinpython、特にnumpyandpandas、aresentialfordataanalysis、offeringspeedandeficiency.1)numpyarraysenable numpyarraysenable handling forlaredatasents andcomplexoperationslikemoverages.2)Pandasextendsnumpy'scapabivitieswithdataframesfortruc

リストのメモリフットプリントは、Pythonの配列のメモリフットプリントとどのように比較されますか?リストのメモリフットプリントは、Pythonの配列のメモリフットプリントとどのように比較されますか?May 02, 2025 am 12:08 AM

listsandnumpyarraysinpythonhavedifferentmemoryfootprints:listsaremoreflexiblellessmemory-efficient、whileenumpyarraysaraysareoptimizedfornumericaldata.1)listsstorereferencesto objects、with whowedaround64byteson64-bitedatigu

実行可能なPythonスクリプトを展開するとき、環境固有の構成をどのように処理しますか?実行可能なPythonスクリプトを展開するとき、環境固有の構成をどのように処理しますか?May 02, 2025 am 12:07 AM

toensurepythonscriptsbehaveCorrectlyAcrossDevelosment、staging、and Production、usetheseStrategies:1)環境variablesforsimplestetings、2)configurationfilesforcomplexsetups、and3)dynamicloadingforadaptability.eachtododododododofersuniquebentandrequiresca

Pythonアレイをどのようにスライスしますか?Pythonアレイをどのようにスライスしますか?May 01, 2025 am 12:18 AM

Pythonリストスライスの基本的な構文はリストです[start:stop:step]。 1.STARTは最初の要素インデックス、2。ストップは除外された最初の要素インデックスであり、3.ステップは要素間のステップサイズを決定します。スライスは、データを抽出するためだけでなく、リストを変更および反転させるためにも使用されます。

どのような状況で、リストは配列よりもパフォーマンスが向上しますか?どのような状況で、リストは配列よりもパフォーマンスが向上しますか?May 01, 2025 am 12:06 AM

ListSoutPerformArraysIn:1)ダイナミシジョンアンドフレーケンティオン/削除、2)ストーリングヘテロゼンダタ、および3)メモリ効率の装飾、ButmayhaveslightPerformancostsinceNASOPERATIONS。

PythonアレイをPythonリストに変換するにはどうすればよいですか?PythonアレイをPythonリストに変換するにはどうすればよいですか?May 01, 2025 am 12:05 AM

toconvertapythonarraytoalist、usetheList()constructororageneratorexpression.1)importhearraymoduleandcreateanarray.2)useList(arr)または[xforxinarr] toconvertoalistは、largedatatessを変えることを伴うものです。

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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。