検索

Making connections

ウィークリーチャレンジ 285

Mohammad S. Anwar は毎週、毎週 2 つのタスクに対する解決策を全員が考え出すチャンスであるウィークリー チャレンジを送信します。私のソリューションは最初に Python で書かれ、次に Perl に変換されます。これは、私たち全員がコーディングを練習するのに最適な方法です。

挑戦、私の解決策

タスク 1: 接続がありません

タスク

ルートのリスト @routes が与えられます。

それ以上発信接続を行わずに宛先を見つけるスクリプトを作成します。

私の解決策

これは非常に簡単なので、多くの説明は必要ありません。 2 つのリストを計算します。起点にはルート リストの最初の値があり、宛先には 2 番目の値があります。

次に、リスト内包表記を使用して、起点リストにない宛先を見つけ、これを行き止まりとして保存します。このリストに項目が 1 つだけ存在しない場合は、エラーが発生します。

def no_connection(routes: list) -> str:
    origins = [v[0] for v in routes]
    destinations = [v[1] for v in routes]
    dead_ends = [d for d in destinations if d not in origins]

    if len(dead_ends) > 1:
        raise ValueError(
            'There are multiple routes with no outgoing connection')

    if len(dead_ends) == 0:
        raise ValueError('All routes have an outgoing connection')

    return dead_ends[0]

$ ./ch-1.py B C C D D A
A

$ ./ch-1.py A Z
Z

タスク 2: 変化を起こす

タスク

指定された金額をセント単位で変更する方法の数を計算します。コインを使用することで、例えばペニー、ニッケル、ダイム、クォーター、ハーフダラー、合計値が所定の金額と等しくなる方法は何通りありますか?コイン選択の順序は関係ありません。

  • 1 ペニー (P) は 1 セントに相当します。
  • ニッケル (N) は 5 セントに相当します。
  • 1 ダイム (D) は 10 セントに相当します。
  • 1 四半期 (Q) は 25 セントに相当します。
  • 1 半ドル (HD) は 50 セントに相当します。

私の解決策

私のコードに (現在は修正されている) バグがあるため、これが完了するまでに予想よりも少し時間がかかりました。 Python と Perl の両方にデバッガがあることは知っていますが、場合によっては print ステートメントに勝てないことがあります :)

久しぶりに再帰関数の使用を必要とするタスクを実行しました。このタスクでは、残りの変更と最後に使用されたコインを取得する Making_change という再帰関数を使用します。最初の呼び出しでは、remaining_change 値を入力に設定し、last_coin 値を None (Perl では undef) に設定します。

各呼び出しは可能なコインを反復処理し、次の 3 つのいずれかを実行します。

  1. コインの値が last_coin の値より大きい場合は、スキップします。これにより、可能な組み合わせが重複することがなくなります。
  2. コインの価値が残りの小銭と同じであれば、有効な解があるので、組み合わせの価値に 1 を加えます。
  3. コインの価値が残りの価値よりも少ない場合は、使用したコインを差し引いた残りの価値で関数を再度呼び出します。

組み合わせの値は上流に渡されるため、最終的な戻り値には正しい数の組み合わせが含まれます。

def making_change(remaining: int, last_coin: int | None = None) -> int:
    combinations = 0

    for coin in [1, 5, 10, 25, 50]:
        if last_coin and last_coin 



<p>再帰には制限があります。 Perl は、再帰が (深さ 100) になると警告します [https://perldoc.perl.org/perldiag#Deep-recursion-on-subroutine-%22%25s%22]。この値は、Perl を再コンパイルすることによってのみ変更できます。デフォルトでは、Python は 995 回の再帰後に (ResursionError)[https://docs.python.org/3/library/Exceptions.html#RecursionError] を発生させますが、この値は実行時に変更できます。</p>

<h3>
  
  
  例
</h3>



<pre class="brush:php;toolbar:false">$ ./ch-2.py 9
2

$ ./ch-2.py 15
6

$ ./ch-2.py 100
292

以上がつながりを作るの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
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を変えることを伴うものです。

Pythonにリストが存在する場合、配列を使用する目的は何ですか?Pythonにリストが存在する場合、配列を使用する目的は何ですか?May 01, 2025 am 12:04 AM

choosearraysoverlistsinperbetterperformance andmemoryeficiencyspecificscenarios.1)largeNumericaldatasets:Araysreducememoryusage.2)パフォーマンス - クリティカル操作:ArraysOfferSpeedBoostsfortsfortsclikeappendedoring.3)タイプリー:Arrayesenforc

リストの要素と配列を繰り返す方法を説明します。リストの要素と配列を繰り返す方法を説明します。May 01, 2025 am 12:01 AM

Pythonでは、ループに使用し、列挙し、包括的なリストを通過することができます。 Javaでは、従来のループを使用し、ループを強化してアレイを通過することができます。 1。Pythonリストトラバーサル方法は、ループ、列挙、およびリスト理解のためのものです。 2。Javaアレイトラバーサル法には、従来のループとループ用の強化が含まれます。

Python Switchステートメントとは何ですか?Python Switchステートメントとは何ですか?Apr 30, 2025 pm 02:08 PM

この記事では、バージョン3.10で導入されたPythonの新しい「マッチ」ステートメントについて説明します。これは、他の言語のスイッチステートメントに相当するものです。コードの読みやすさを向上させ、従来のif-elif-elよりもパフォーマンスの利点を提供します

Pythonの例外グループとは何ですか?Pythonの例外グループとは何ですか?Apr 30, 2025 pm 02:07 PM

Python 3.11の例外グループは、複数の例外を同時に処理することで、同時シナリオと複雑な操作でエラー管理を改善します。

Pythonの関数注釈とは何ですか?Pythonの関数注釈とは何ですか?Apr 30, 2025 pm 02:06 PM

Pythonの関数注釈は、タイプチェック、ドキュメント、およびIDEサポートの関数にメタデータを追加します。それらはコードの読みやすさ、メンテナンスを強化し、API開発、データサイエンス、ライブラリの作成において重要です。

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 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

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

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

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