検索
ホームページバックエンド開発Python チュートリアルPython の辞書とハッシュ テーブル、およびハッシュ競合の解決に関する簡単な説明

この記事の内容は、Python の辞書とハッシュ テーブルに関する簡単な説明と、ハッシュ競合の解決に関するものです。一定の参考価値があります。必要な友人は参照できます。お役に立てれば幸いです。

Python はハッシュ テーブルを使用して dict を実装します。

ハッシュ テーブルは実際にはスパース配列です (常に空白の要素を持つ配列をスパース配列と呼びます)。一般書籍では、ハッシュテーブルの単位をバケットと呼ぶことが多いです。存在する 辞書 ハッシュ テーブルでは、各キーと値のペアがテーブル要素を占め、各テーブル要素には 2 つの部分があり、1 つはキーへの参照、もう 1 つは値への参照です。表の各セルは同じサイズであるため、オフセットによって表のセルを読み取ることができます。

Python は、テーブル要素の約 3 分の 1 が空であることを確認しようとします。このしきい値にほぼ達すると、元のハッシュ テーブルを拡張して、より大きなハッシュ テーブルにコピーします。

オブジェクトをハッシュ テーブルに追加する場合は、まず要素キーのハッシュ値を計算する必要があります。これには、キーがハッシュ可能である必要があります。

ハッシュ可能オブジェクトは次の条件を満たす必要があります:

hash() 関数をサポートし、__hash__() メソッドを通じて取得されたハッシュ値は変更されません。

__eq__() メソッドによる等価検出をサポートします。

a == b が true の場合、hash(a) == hash(b) も true になります。

以下では主にハッシュテーブルのアルゴリズムについて説明します。

キーを取得するには search_key に対応する値 search_value 。Python は最初に hash(search_key) を呼び出して計算します。 検索キー 値のハッシュ値、この値の最下位数桁がオフセットとして使用され、ハッシュ テーブル内でテーブル要素が検索されます (特定の数値は現在のハッシュ テーブルのサイズによって異なります)。見つかったテーブル要素が空の場合、KeyError がスローされます 例外; 空でない場合は、テーブル要素に found_key:found_value のペアが存在します。search_key と found_key を確認してください。 それらが等しいかどうか、等しい場合は、found_value を返します。それらが等しくない場合、この状況はハッシュ衝突と呼ばれます。

ハッシュの競合を解決するために、アルゴリズムはハッシュ値のさらに数ビットを取得し、それを特別な方法で処理し、取得した新しい値をオフセットとして使用して検索します。ハッシュ テーブルのテーブル要素。見つかったテーブル要素が空の場合は、KeyError 例外もスローされます。空でない場合は、キーを比較して一貫性があるかどうかを確認し、一貫性がある場合は対応する値を返します。ハッシュの競合が見つかった場合は、上記の手順を繰り返します。

新しい要素の追加は上記のプロセスとほぼ同じですが、空のテーブル要素が見つかった場合に新しい要素が追加される点が異なります。空でない場合は、ハッシュが繰り返され、検索は続行されます。

いつ行くか 新しい要素が辞書に追加され、ハッシュの競合が発生した場合、新しい要素は別の場所に格納されるように調整される可能性があります。したがって、次の状況が発生します: dict([key1, value1], [key2, value2]) および dict([key2, value2], [key1, value1]) 2 つの辞書を比較すると等しいですが、key1 と key2 のハッシュが競合する場合、辞書内の 2 つのキーの順序は異なります。

いつでも行ってください dict、pythonに新しいキーを追加します パーサーは辞書を拡張することを決定する場合があります。拡張の結果、より大きなハッシュ テーブルが作成され、ディクショナリ内の既存の要素が新しいハッシュ テーブルに追加されます。このプロセス中に新しいハッシュの競合が発生し、新しいハッシュ テーブル内のキーの順序が変更される可能性があります。新しいキーを追加しながら辞書を反復処理するとどうなるでしょうか?残念ながら容量が拡張されましたが、残念ながらキーの順番が変わってしまいました。 orz。

ハッシュ テーブルはスパースである必要があるため、その消費スペースはさらに大きくなる必要があり、これは一般的なスペースと時間のトレードオフです。

以上がPython の辞書とハッシュ テーブル、およびハッシュ競合の解決に関する簡単な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事は博客园で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
Pythonの主な目的:柔軟性と使いやすさPythonの主な目的:柔軟性と使いやすさApr 17, 2025 am 12:14 AM

Pythonの柔軟性は、マルチパラダイムサポートと動的タイプシステムに反映されていますが、使いやすさはシンプルな構文とリッチ標準ライブラリに由来しています。 1。柔軟性:オブジェクト指向、機能的および手続き的プログラミングをサポートし、動的タイプシステムは開発効率を向上させます。 2。使いやすさ:文法は自然言語に近く、標準的なライブラリは幅広い機能をカバーし、開発プロセスを簡素化します。

Python:汎用性の高いプログラミングの力Python:汎用性の高いプログラミングの力Apr 17, 2025 am 12:09 AM

Pythonは、初心者から上級開発者までのすべてのニーズに適した、そのシンプルさとパワーに非常に好まれています。その汎用性は、次のことに反映されています。1)学習と使用が簡単、シンプルな構文。 2)Numpy、Pandasなどの豊富なライブラリとフレームワーク。 3)さまざまなオペレーティングシステムで実行できるクロスプラットフォームサポート。 4)作業効率を向上させるためのスクリプトおよび自動化タスクに適しています。

1日2時間でPythonを学ぶ:実用的なガイド1日2時間でPythonを学ぶ:実用的なガイドApr 17, 2025 am 12:05 AM

はい、1日2時間でPythonを学びます。 1.合理的な学習計画を作成します。2。適切な学習リソースを選択します。3。実践を通じて学んだ知識を統合します。これらの手順は、短時間でPythonをマスターするのに役立ちます。

Python vs. C:開発者の長所と短所Python vs. C:開発者の長所と短所Apr 17, 2025 am 12:04 AM

Pythonは迅速な開発とデータ処理に適していますが、Cは高性能および基礎となる制御に適しています。 1)Pythonは、簡潔な構文を備えた使いやすく、データサイエンスやWeb開発に適しています。 2)Cは高性能で正確な制御を持ち、ゲームやシステムのプログラミングでよく使用されます。

Python:時間のコミットメントと学習ペースPython:時間のコミットメントと学習ペースApr 17, 2025 am 12:03 AM

Pythonを学ぶのに必要な時間は、人によって異なり、主に以前のプログラミングの経験、学習の動機付け、学習リソースと方法、学習リズムの影響を受けます。現実的な学習目標を設定し、実用的なプロジェクトを通じて最善を尽くします。

Python:自動化、スクリプト、およびタスク管理Python:自動化、スクリプト、およびタスク管理Apr 16, 2025 am 12:14 AM

Pythonは、自動化、スクリプト、およびタスク管理に優れています。 1)自動化:OSやShutilなどの標準ライブラリを介してファイルバックアップが実現されます。 2)スクリプトの書き込み:Psutilライブラリを使用してシステムリソースを監視します。 3)タスク管理:スケジュールライブラリを使用してタスクをスケジュールします。 Pythonの使いやすさと豊富なライブラリサポートにより、これらの分野で優先ツールになります。

Pythonと時間:勉強時間を最大限に活用するPythonと時間:勉強時間を最大限に活用するApr 14, 2025 am 12:02 AM

限られた時間でPythonの学習効率を最大化するには、PythonのDateTime、時間、およびスケジュールモジュールを使用できます。 1. DateTimeモジュールは、学習時間を記録および計画するために使用されます。 2。時間モジュールは、勉強と休息の時間を設定するのに役立ちます。 3.スケジュールモジュールは、毎週の学習タスクを自動的に配置します。

Python:ゲーム、GUIなどPython:ゲーム、GUIなどApr 13, 2025 am 12:14 AM

PythonはゲームとGUI開発に優れています。 1)ゲーム開発は、2Dゲームの作成に適した図面、オーディオ、その他の機能を提供し、Pygameを使用します。 2)GUI開発は、TKINTERまたはPYQTを選択できます。 TKINTERはシンプルで使いやすく、PYQTは豊富な機能を備えており、専門能力開発に適しています。

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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

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

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

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

PhpStorm Mac バージョン

PhpStorm Mac バージョン

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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