国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

ヒープ - Min e Max

Nov 03, 2024 pm 09:06 PM

Heap - Min e Max

ヒープ - 最小ヒープ

ヒープは、優(yōu)先順位リストのより効率的なバージョンです。プライオリティ キューのソート済みおよびアンソートの挿入および削除方法を考慮します。アンソートでは挿入コスト O(1)、削除コスト O(n) がかかりますが、ソート済みの挿入コストは O(n)、削除コスト O(1) です。

sorted unsorted
insert O(n) O(1)
remove O(1) O(n)

ヒープは配列によって構(gòu)築されますが、その表現(xiàn)はバイナリ ツリーであり、最も優(yōu)先度の高い要素が最上位のルートになります。上から下、右から左まで満たされており、欠けている子はありません!

?

ただし、最も高いキー値によって定義される最も高い優(yōu)先順位を持つデータ構(gòu)造が構(gòu)築される可能性があります。この場合、最大ヒープが得られます。これについては後で説明します。

最小ヒープ

有効なヒープであるためには、すべての子要素の優(yōu)先順位が親要素よりも低いか同じである必要があります。さらに、欠落した子がなく完全である必要があります。そうでない場合、配列には空白スペースが生じます。

?

この定義をより正式に実行する方法は、レベル 0、1、2、... h ? 1 に可能な最大の要素があり、レベル h に存在する要素が割り當(dāng)てられている場合にバイナリ ツリーが完成すると言うことです。できるだけ左に。

前述したように、ヒープは配列 (緑色で表示) で構(gòu)成されていますが、以下の畫像に示すようにツリー構(gòu)造として見ることができます。

ヒープをアセンブルするには、最初の要素を位置 0 に配置する方法と、位置 0 を使用しない方法の 2 つがあります。この記事では、2 つの場合の違いについて説明します。上部の要素には常にその子があり、一般に下部の要素として知られています。これらの子を検出するには、インデックス 0 の場合、次の計算を使用してこの情報を取得できます。

rigthChild = LeftChild + 1
//para saber o elemento da esquerda do pai
leftChild = indexDoFilho * 2 +1
//para saber qual o pai do elemento
parent = (indexDoFilho -1)/2

0 が入力されていないバージョンを使用する場合は、合計を減らすだけです。つまり、1-1=0、親の場合はインデックス / 2 です。

入れる

これは常に最後に追加されます。唯一の懸念は、子要素が親よりも低いキーを持っているかどうかを確認するときです。このために、挿入された要素のキーが更新されるときにバブリングアップが実行されます。必要に応じて変化する父親と比較してください。

より詳しく言うと、要素をツリーの最後の空きスペースに配置し、そのキーと親のキーを比較する必要があるため、そのキーにアクセスするために親のインデックスを計算する必要があります。父親を調(diào)べるには、次の計算を使用します。

parent = (indexDoFilho -1)/2

そして、この場合、indexDoFilho が欠落しています。これを取得するには、変數(shù)を現(xiàn)在のインデックスとして取ります。最後に追加である挿入を行っているため、現(xiàn)在のインデックスは最後のもので、次のようになります。

currentIndex = size-1

現(xiàn)在のインデックスが得られたので、Parent を呼び出し、挿入される要素の父親が誰であるかを確認します。この新しい要素の親が必要なのは、ツリーを正しく構(gòu)成するには、この要素をその親と比較する必要があり、そのキーが小さい場合は位置を交換する必要があるためです。

現(xiàn)在のインデックスが 0 より大きく (使用できないインデックスの選択を避けるため)、現(xiàn)在のインデックスが親のインデックスより小さい限り、この條件が true の場合、要素は親と交換する必要があります。最小ヒープの所有権を保証するため、スワップが発生し、現(xiàn)在のインデックスが親のインデックスを受け取り、親の親 (KKKKK) を に取得します。スワップは、通常の価値交換の仕組みを利用した手法です。

rigthChild = LeftChild + 1
//para saber o elemento da esquerda do pai
leftChild = indexDoFilho * 2 +1
//para saber qual o pai do elemento
parent = (indexDoFilho -1)/2

関連性があること:

parent = (indexDoFilho -1)/2

スワップは値を交換する通常の方法です:

currentIndex = size-1

現(xiàn)在の (子) 要素の値が親の値より小さい場合、これは最小ヒープ プロパティに違反していることを示します。最小ヒープでは、親は常に子以下でなければなりません。 この條件が満たされない場合、子は親と場所を交換する必要があります。これにより、プロパティが維持される正しい位置が見つかるまで、小さい値がヒープ內(nèi)で「登り」続けます。

>

取り除く

インデックス 0 の要素を削除しますが、ツリーは完成しません。これを解決するには、配列の最後の要素を先頭にプルします。つまり、追加された最後の要素がツリーの先頭に移動します。その後、もう一度確認しますが、今度は上から下まで確認します。つまり、今こそ親と子を比較する時期なのです! (沈下)
SinkDown() メソッドは、要素が正しい位置に配置されるまで、要素をヒープ內(nèi)で下に移動します (または「シンク」します)。要素の値はその子の値以下になります (子のある位置にある場合)。 .
SinkDown には、ルートから始まる最小キーを持つ要素のインデックスを格納する変數(shù)と、現(xiàn)在のインデックス用の変數(shù)があります。次に、現(xiàn)在の要素のインデックスが最も低いキーを持つ要素のインデックスと等しくなるまでループが続きます。ループ內(nèi)で、現(xiàn)在の子の子を取得し、子が配列範(fàn)囲內(nèi)にあるかどうかを確認します。子のインデックスが最小インデックスより小さい場合は、最小値を更新します。

public void insert(K key, V value) { //o(log n)
    if (isFull()){
        throw new RuntimeException("full");
    }
    //adc a entry na ultima posi??o do vetor
    heap[size++]=new PriorityEntry(key, value);
    //guarda o index que esse novo elemento tá
    int currentIndex = size-1;
    //chama o método parent pra calcular quem é o pai do novo elemento
    int parent = parent(currentIndex);
    //percorre enquanto o index nao for o 0 e o index ser 
    while (currentIndex>0 && compare(currentIndex, parent)<0){
        swap(currentIndex, parent);
        currentIndex = parent;
        parent = parent(currentIndex);
    }
}

この場合:

protected int parent(int index){
        return (index-1)/2;
}

まとめ:

最小ヒーププロパティ:

  • 完全なバイナリ ツリー構(gòu)造。
  • 親ノードは常にその子ノード以下の値を持ちます。
  • 配列を介して実裝され、子と親の位置はインデックスに基づく數(shù)式によって決定されます。

子と親の位置を計算するには:

  • : leftChild = インデックス * 2 1
  • : rightChild = インデックス * 2 2
  • : 親 = (インデックス - 1) / 2

インデックス 0 のないバージョン: 計算から 1 を引くだけで、結(jié)果は次のようになります:

  • leftChild = インデックス * 2
  • rightChild = インデックス * 2 1
  • 親 = インデックス / 2

ヒープ - 最大ヒープ

最高値はルートにあるため、親ノードの値は子ノードと同じかそれより大きくなります

子と親の計算式:

  • : leftChild = インデックス * 2 1
  • : rightChild = インデックス * 2 2
  • : 親 = (インデックス - 1) / 2

入れる

要素を最後に追加してバブルアップします。これにより、要素とその親が比較され、必要に応じて位置が変更されます。 O(log n).

rigthChild = LeftChild + 1
//para saber o elemento da esquerda do pai
leftChild = indexDoFilho * 2 +1
//para saber qual o pai do elemento
parent = (indexDoFilho -1)/2

取り除く

heapMax[0] 要素 (別名ルート) を削除し、最後の要素を取得してルートに移動し、sinkdown を呼び出して、正しい位置が見つかるまで新しい要素をルートから下にプッシュします。

sinkDown は、親ノードの値が子ノードの値以上であることを確認する必要があります。したがって、ノードをシンクするときは、最大の子と比較されます。

最小ヒープでは、sinkDown は親ノードの値が子の値以下であることを確認する必要があります。この場合、比較は一番小さい子と行われます。

parent = (indexDoFilho -1)/2
currentIndex = size-1

違い

  • 最大ヒープでは、sinkDown は親ノードの値が子ノードの値以上であることを確認する必要があります。したがって、ノードをシンクするときは、最大の子と比較されます。
  • 最大ヒープでは、親ノードがその子の最大値よりも小さい場合、最大値ができるだけ大きくなるように、最大??の子ノードとスワップする必要があります。
  • 最小ヒープでは、sinkDown は親ノードの値が子の値以下であることを確認する必要があります。この場合、比較は一番小さい子と行われます。
  • 最小ヒープでは、親ノードが子ノードの最小値よりも大きい場合に切り替えが発生し、最小値が先頭に維持されます

以上がヒープ - Min e Maxの詳細內(nèi)容です。詳細については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中國語版

SublimeText3 中國語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

現(xiàn)代のジャワの非同期プログラミング技術(shù) 現(xiàn)代のジャワの非同期プログラミング技術(shù) Jul 07, 2025 am 02:24 AM

Javaは、Java19での完了可能なストリーム(ProjectReactorなど)、仮想スレッドの使用など、非同期プログラミングをサポートしています。 1.CompletableFutureチェーンコールを通じてコードの読みやすさとメンテナンスを改善し、タスクオーケストレーションと例外処理をサポートします。 2。ProjectReactorは、バックプレッシャーメカニズムとリッチ演算子を備えた応答性プログラミングを?qū)g裝するためのモノとフラックスタイプを提供します。 3.仮想スレッドは、同時性コストを削減し、I/O集約型タスクに適しており、従來のプラットフォームスレッドよりも軽量で拡張が容易です。各方法には適用可能なシナリオがあり、適切なツールをお客様のニーズに応じて選択する必要があり、混合モデルはシンプルさを維持するために避ける必要があります

Javaで酵素を使用するためのベストプラクティス Javaで酵素を使用するためのベストプラクティス Jul 07, 2025 am 02:35 AM

Javaでは、列挙は固定定數(shù)セットを表すのに適しています。ベストプラクティスには以下が含まれます。1。列挙を使用して固定狀態(tài)またはオプションを表して、タイプの安全性と読みやすさを改善します。 2.フィールド、コンストラクター、ヘルパーメソッドなどの定義など、柔軟性を高めるために、酵素にプロパティとメソッドを追加します。 3. enummapとEnumsetを使用して、パフォーマンスとタイプの安全性を向上させ、配列に??基づいてより効率的であるためです。 4.動的値、頻繁な変更、複雑なロジックシナリオなどの列挙の悪用を避けてください。これらは他の方法に置き換える必要があります。列挙の正しい使用は、コードの品質(zhì)を改善し、エラーを減らすことができますが、適用される境界に注意を払う必要があります。

Java Nioとその利點を理解する Java Nioとその利點を理解する Jul 08, 2025 am 02:55 AM

Javanioは、Java 1.4によって導(dǎo)入された新しいIoapiです。 1)バッファとチャネルを?qū)澫螭趣筏皮い蓼埂?)バッファ、チャネル、セレクターのコアコンポーネント、3)ノンブロッキングモードをサポートし、4)従來のIOよりも効率的に並行接続を処理します。その利點は、次のことに反映されます。1)非ブロッキングIOはスレッドオーバーヘッドを減らし、2)データ送信効率を改善し、3)セレクターがマルチプレックスを?qū)g現(xiàn)し、4)メモリマッピングはファイルの読み取りと書き込みを速めます。注:1)バッファのフリップ/クリア操作は混亂しやすく、2)不完全なデータをブロックせずに手動で処理する必要があります。3)セレクター登録は時間內(nèi)にキャンセルする必要があります。4)NIOはすべてのシナリオに適していません。

Java Classloadersの動作方法 Java Classloadersの動作方法 Jul 06, 2025 am 02:53 AM

Javaのクラスロードメカニズムはクラスローダーを介して実裝されており、そのコアワークフローは、読み込み、リンク、初期化の3つの段階に分けられます。ローディングフェーズ中、クラスローダーはクラスのバイトコードを動的に読み取り、クラスオブジェクトを作成します。リンクには、クラスの正しさの確認、靜的変數(shù)へのメモリの割り當(dāng)て、およびシンボル?yún)⒄栅谓馕訾蓼欷蓼?。初期化は、靜的コードブロックと靜的変數(shù)割り當(dāng)てを?qū)g行します。クラスの読み込みは、親クラスローダーに優(yōu)先順位を付けてクラスを見つけ、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを順番に試して、コアクラスライブラリが安全であり、重複した負荷を回避することを確認します。開発者は、urlclasslなどのクラスローダーをカスタマイズできます

ハッシュマップはJavaで內(nèi)部的にどのように機能しますか? ハッシュマップはJavaで內(nèi)部的にどのように機能しますか? Jul 15, 2025 am 03:10 AM

HashMapは、Javaのハッシュテーブルを介してキーと値のペアストレージを?qū)g裝し、そのコアはデータの位置をすばやく配置することにあります。 1.最初にキーのHashCode()メソッドを使用して、ハッシュ値を生成し、ビット操作を介して配列インデックスに変換します。 2。異なるオブジェクトは、同じハッシュ値を生成し、競合をもたらす場合があります。この時點で、ノードはリンクされたリストの形式で取り付けられています。 JDK8の後、リンクされたリストが長すぎ(デフォルトの長さ8)、効率を改善するために赤と黒の木に変換されます。 3.カスタムクラスをキーとして使用する場合、equals()およびhashcode()メソッドを書き直す必要があります。 4。ハッシュマップは容量を動的に拡大します。要素の數(shù)が容量を超え、負荷係數(shù)(デフォルト0.75)を掛けた場合、拡張して再ハッシュします。 5。ハッシュマップはスレッドセーフではなく、マルチスレッドでconcuを使用する必要があります

Java EnumsとBest Practicesの効果的な使用 Java EnumsとBest Practicesの効果的な使用 Jul 07, 2025 am 02:43 AM

Javaの列挙は、定數(shù)を表すだけでなく、動作をカプセル化し、データをキャリーし、インターフェイスを?qū)g裝することもできます。 1.列挙は、週や狀態(tài)などの固定インスタンスを定義するために使用されるクラスであり、文字列や整數(shù)よりも安全です。 2。コンストラクターに値を渡すことやアクセス方法の提供など、データとメソッドを運ぶことができます。 3.スイッチを使用して、明確な構(gòu)造を持つさまざまなロジックを処理できます。 4.さまざまな列挙値の差別化された動作を作成するためのインターフェイスまたは抽象的なメソッドを?qū)g裝できます。 5.虐待、ハードコードの比較、順序の値への依存、合理的に命名とシリアル化を避けるために注意してください。

Javaで例外を適切に処理する方法は? Javaで例外を適切に処理する方法は? Jul 06, 2025 am 02:43 AM

Javaの例外を処理するための鍵は、それらをキャッチし、それらを明確に処理し、問題を隠さないことです。まず、必要に応じて特定の例外タイプをキャッチし、一般的なキャッチを避け、CheckEdexceptionsを優(yōu)先順位付けする必要があります。ランタイムの例外は事前に審査する必要があります。次に、ログフレームワークを使用して例外を記録し、タイプに基づいて再試行、ロールバック、またはスローする必要があります。第三に、最終的なブロックを使用してリソースをリリースする必要があり、リソース付きの試行をお勧めする必要があります。第4に、カスタムの例外を合理的に定義し、runtimeexceptionまたは例外を継承し、簡単にデバッグするためのコンテキスト情報を伝達する必要があります。

JavaのSingletonデザインパターンとは何ですか? JavaのSingletonデザインパターンとは何ですか? Jul 09, 2025 am 01:32 AM

JavaのSingleton Design Patternは、クラスに1つのインスタンスしかないことを保証し、プライベートコンストラクターと靜的方法を介したグローバルアクセスポイントを提供することを保証します。これは、共有リソースへのアクセスを制御するのに適しています。実裝方法には以下が含まれます。1。レイジーロード、つまり、インスタンスは最初のリクエストが要求されたときにのみ作成されます。これは、リソースの消費が高く、必ずしも必要ではない狀況に適しています。 2。スレッドセーフ処理。同期方法または再確認ロックを介して、マルチスレッド環(huán)境で1つのインスタンスのみが作成され、パフォーマンスへの影響が低下するようにします。 3.クラスの読み込み中にインスタンスを直接初期化するHungry Loadingは、事前に初期化できる軽量オブジェクトまたはシナリオに適しています。 4.列挙の実裝は、Java列挙を使用してシリアル化、スレッドの安全性をサポートし、反射攻撃を防止することは、推奨される簡潔で信頼できる方法です。特定のニーズに応じて、さまざまな実裝方法を選択できます

See all articles