分割統治再帰のための高度なマスター定理
分割統治は、問題を同様のタイプの複数のサブ問題に再帰的に分解することに基づいたアルゴリズムであり、これらのサブ問題は簡単に解決できます。
例
分割統治手法をより深く理解するために例を挙げてみましょう -
function recursive(input x size n) if(n < k) Divide the input into m subproblems of size n/p. and call f recursively of each sub problem else Solve x and return
すべての部分問題の結果を結合し、元の問題の解を返します。
説明 - 上記の問題では、問題セットは簡単に解決できる小さなサブ問題に再分割されます。
分割統治のマスター定理 は、再帰関係アルゴリズムのビッグ 0 値を決定するために使用できる分析定理です。アルゴリズムに必要な時間を見つけて、漸近表記形式で表すために使用されます。
例上記の例の問題の実行時値 -
T(n) = f(n) + m.T(n/p)
ほとんどの再帰的アルゴリズムでは、マスターの定理を使用するアルゴリズムの時間計算量を見つけることができますが、場合によってはマスターの定理が見つからない場合もあります。これらはマスターの定理が適用できない場合です。問題 T(n) が単調でない場合、たとえば、T(n) = sin n です。問題関数 f(n) は多項式ではありません。
このような場合、時間計算量を求めるためのマスター定理は効率的ではないため、再帰的再帰のための高度なマスター定理が設計されました。これは、-
T(n) = aT(n/b) + ø((n^k)logpn)
の形式の再帰問題を処理するように設計されています。 n は問題の規模です。
a = 再帰内の部分問題の数、a > 0
n/b = 各部分問題のサイズ b > 1、k >= 0、p は実数です。
このタイプの問題を解決するには、次の解決策を使用します:
- If a > bk, then T(n) = ∅ ( nlogba)
- If a = bk, then
- If p > -1, then T(n) = ∅(nlogba logp 1n )
- p = -1 の場合、T(n) = ∅(nlogba loglogn)
- p ba)
- If a k, then
- if p > = 0 , then T(n) = ∅(nklogpn)
- p
高レベルのマスター アルゴリズムを使用して、いくつかのアルゴリズムの複雑さを計算します。 -
二分探索 - t(n) = θ ( logn)
マージソート − T(n) = θ(nlogn)
以上が分割統治再帰のための高度なマスター定理の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









C++ 関数の再帰の深さは制限されており、この制限を超えるとスタック オーバーフロー エラーが発生します。制限値はシステムやコンパイラによって異なりますが、通常は 1,000 ~ 10,000 の間です。解決策には次のものが含まれます: 1. 末尾再帰の最適化、2. 末尾呼び出し、3. 反復実装。

はい、C++ ラムダ式は std::function を使用して再帰をサポートできます。std::function を使用して Lambda 式への参照をキャプチャします。キャプチャされた参照を使用すると、ラムダ式はそれ自体を再帰的に呼び出すことができます。

再帰アルゴリズムは、関数の自己呼び出しを通じて構造化された問題を解決します。利点は、シンプルで理解しやすいことですが、欠点は、効率が低く、スタック オーバーフローを引き起こす可能性があることです。非再帰アルゴリズムは、明示的に管理することで再帰を回避します。スタック データ構造の利点は、より効率的でスタックのオーバーフローを回避できることですが、欠点はコードがより複雑になる可能性があることです。再帰的か非再帰的かの選択は、問題と実装の特定の制約によって異なります。

2 つの文字列 str_1 と str_2 を指定します。目的は、再帰的プロシージャを使用して、文字列 str1 内の部分文字列 str2 の出現数をカウントすることです。再帰関数は、その定義内で自分自身を呼び出す関数です。 str1 が「Iknowthatyouknowthatiknow」、str2 が「know」の場合、出現回数は -3 になります。例を通して理解しましょう。たとえば、入力 str1="TPisTPareTPamTP"、str2="TP"; 出力 Countofoccurrencesofasubstringrecursi

整数配列 Arr[] を入力として受け取ります。目標は、再帰的メソッドを使用して配列内の最大要素と最小要素を見つけることです。再帰を使用しているため、長さ = 1 に達するまで配列全体を反復処理し、基本ケースを形成する A[0] を返します。それ以外の場合、現在の要素は現在の最小値または最大値と比較され、その値は後続の要素に対して再帰的に更新されます。この場合のさまざまな入出力シナリオを見てみましょう −入力 −Arr={12,67,99,76,32}; 出力 −配列内の最大値: 99 説明 &mi

Python は学習と使用が簡単なプログラミング言語ですが、Python を使用して再帰関数を作成すると、再帰の深さが大きすぎるエラーが発生する可能性があるため、この問題を解決する必要があります。この記事では、Python の最大再帰深さエラーを解決する方法を説明します。 1. 再帰の深さを理解する 再帰の深さとは、入れ子になった再帰関数の層の数を指します。 Python のデフォルトでは、再帰の深さの制限は 1000 です。再帰レベルの数がこの制限を超えると、システムはエラーを報告します。このエラーは「最大再帰深さエラー」と呼ばれることがよくあります。

Vue フォーム処理を使用してフォームの再帰的ネストを実装する方法 はじめに: フロントエンド データ処理とフォーム処理が複雑になるにつれて、複雑なフォームを処理する柔軟な方法が必要です。人気のある JavaScript フレームワークとして、Vue はフォームの再帰的なネストを処理するための多くの強力なツールと機能を提供します。この記事では、Vue を使用してこのような複雑なフォームを処理する方法を紹介し、コード例を添付します。 1. フォームの再帰的なネスト シナリオによっては、再帰的なネストに対処する必要がある場合があります。

再帰関数は、文字列処理の問題を解決するためにそれ自体を繰り返し呼び出す手法です。無限再帰を防ぐために終了条件が必要です。再帰は、文字列の反転や回文チェックなどの操作で広く使用されています。
