検索

Advent of Code  Day  Linen Layout

19日目: リネンのレイアウト

GitHub ソリューション

今日の課題は、通常の 2D パズルとダイクストラのアルゴリズムからの新鮮な変化でした。私のアプローチ方法は次のとおりです:

パート 1

目標は簡単です。利用可能なタオルを使用して、指定されたタオルの配置を作成できるかどうかを確認することです。

してはいけないこと:

最初に、itertools.combinations を使用して、考えられるすべてのタオルの組み合わせを生成しようとしました。これは実用的でも効率的でもないことがすぐに明らかになりました。

効果があったもの:

辞書 (メモ) と組み合わせた再帰を使用して、すでに処理されたデザインをキャッシュします。これにより、冗長な計算が防止され、ソリューションの効率が大幅に向上します。

仕組み:

各デザインの先頭をタオルのパターンの 1 つと合わせてみてください。
一致するものがあれば、一致した部分を削除し、残りを再帰的に処理します。
メモを使用して、すでにチェックしたデザインの結果をキャッシュし、重複した作業を避けます。
メモ化による再帰的アプローチにより、大規模な入力であっても複雑さが管理可能に保たれ、ソリューションが効率的に実行されます。

パート 2
2 番目の部分では、ハードルが上がりました。利用可能なパターンを使用して各タオルのデザインを作成する方法の数を数えます。

重要な洞察:
count_arrangements 関数はパート 1 の再帰ロジックを拡張していますが、デザインを構築するために考えられるすべての方法を計算するようになりました。

一致するタオルごとに、デザインの残りの部分を再帰的に実行します。
別の辞書 (memo_count) を使用して、以前に解決した部分問題の結果をキャッシュします。

例:
「brgr」が 2 つの方法で構築できる場合は、再計算するのではなく、単純にキャッシュから 2 を返します。

最適化:
パート 1 のおかげで、どのようなデザインが可能であるかはすでにわかりました。私たちはそれらの手配のみを計算します。

すべての有効な方法を合計すると、パート 2 の最終的な答えが得られます。これは非常に簡単です。

私が言ったように、今日のチャレンジはとても楽しくて、良い気分転換になりました。この記事が今後の課題やコーディングに役立つことを願っています。

いつものように、お気軽にフォローしたり、Twitter にご連絡ください

以上がCode Day の到来 リネンのレイアウトの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

PythonListsareimplementedasdynamicarrays、notlinkedlists.1)they restorediguourmemoryblocks、それはパフォーマンスに影響を与えることに影響を与えます

Pythonリストから要素をどのように削除しますか?Pythonリストから要素をどのように削除しますか?May 07, 2025 am 12:15 AM

pythonoffersfourmainmethodstoremoveelements fromalist:1)removesthefirstoccurrenceofavalue、2)pop(index(index(index)removes regvess returnsaspecifiedindex、3)delstatementremoveselementselementsbyindexorseLice、および4)clear()

スクリプトを実行しようとするときに「許可を拒否された」エラーを取得した場合、何を確認する必要がありますか?スクリプトを実行しようとするときに「許可を拒否された」エラーを取得した場合、何を確認する必要がありますか?May 07, 2025 am 12:12 AM

toresolvea "許可denided" errors whenrunningascript、sofflowthesesteps:1)checkandadaddadaddadadaddaddadadadaddadaddadaddadaddaddaddaddaddadaddadaddaddaddaddadaddaddaddadadaddadaddadaddadadisionsisingmod xmyscript.shtomakeitexexutable.2)

Arrayは、Pythonでの画像処理でどのように使用されていますか?Arrayは、Pythonでの画像処理でどのように使用されていますか?May 07, 2025 am 12:04 AM

ArraySarecrucialinpythonimageprocessing asheyenable efficientmanipulation analysisofimagedata.1)画像anverttonumpyArrays、with grayscaleimagesasas2darraysandcolorimagesas.

リストよりも大幅に高速な配列の操作はどのような種類ですか?リストよりも大幅に高速な配列の操作はどのような種類ですか?May 07, 2025 am 12:01 AM

有意に発生することは、採用中に採用されていることを確認してください

リストと配列間の要素ごとの操作のパフォーマンスの違いを説明します。リストと配列間の要素ごとの操作のパフォーマンスの違いを説明します。May 06, 2025 am 12:15 AM

ArsareSareBetterElement-WiseOperationsduetof of ActassandoptimizedImplementations.1)ArrayshaveContigUousMoryFordiRectAccess.2)ListSareFlexibleButSlowerDueTopotentialDynamicresizizizizing.3)

numpyアレイ全体で数学操作を効率的に実行するにはどうすればよいですか?numpyアレイ全体で数学操作を効率的に実行するにはどうすればよいですか?May 06, 2025 am 12:15 AM

Numpyの配列全体の数学的操作は、ベクトル化された操作を通じて効率的に実装できます。 1)追加(arr 2)などの簡単な演算子を使用して、配列で操作を実行します。 2)Numpyは、基礎となるC言語ライブラリを使用して、コンピューティング速度を向上させます。 3)乗算、分割、指数などの複雑な操作を実行できます。 4)放送操作に注意して、配列の形状が互換性があることを確認します。 5)np.sum()などのnumpy関数を使用すると、パフォーマンスが大幅に向上する可能性があります。

Pythonアレイに要素を挿入するにはどうすればよいですか?Pythonアレイに要素を挿入するにはどうすればよいですか?May 06, 2025 am 12:14 AM

Pythonでは、要素をリストに挿入するための2つの主要な方法があります。1)挿入(インデックス、値)メソッドを使用して、指定されたインデックスに要素を挿入できますが、大きなリストの先頭に挿入することは非効率的です。 2)Append(Value)メソッドを使用して、リストの最後に要素を追加します。これは非常に効率的です。大規模なリストの場合、append()を使用するか、dequeまたはnumpy配列を使用してパフォーマンスを最適化することを検討することをお勧めします。

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

ホットツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

SublimeText3 中国語版

SublimeText3 中国語版

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

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール