最大部分列和アルゴリズム解析、部分列アルゴリズム解析_PHPチュートリアル
最大部分列とアルゴリズム分析、部分列アルゴリズム分析
問題の説明: n 個の整数列 {a1, a2,...,an} が与えられた場合、関数 f(i,j)=max{0, Σak を見つけます}(k: i から j まで連続的に取得);
問題は、連続するサブ列の合計の最大値を見つけることです。最大値が負の数の場合は、0 を取ります。たとえば、8 つの数値シーケンス {-1,2,-3,4,-2)。 ,5,-8, 3}、Namo の最大部分列合計は 4+(-2)+5=7 です。
この問題には複雑度の異なる 4 つのアルゴリズムがあり、アルゴリズム 1 から 4 の時間計算量は O(n3)、O(n2)、O(nlogn)、O(n);
アルゴリズム 1:
最も直接的な方法は、すべての状況をリストし、部分列の左端 i と右端 j を設定し、1 つのレイヤーを使用して a[i] から a[j] までの合計を計算します。
//最大のサブカラムと網羅的なメソッド#include
using namespace std;
int Find_Maxsun(int*a, int n);
int main(){
int n, i;
int a[100 ];
cin >>
cout << "数値:" <
cout<
}
int Find_Maxsun(int*a, int n) MaxSun = 0, i, j, k;
int NowSum;
for (i = 0; i
NowSum = 0;
for (k = i; k <= j; k++)
NowSum += a[k] /* a[i] から a[j] へ*/
if (NowSum>MaxSun)
MaxSun = NowSum のシーケンス /*結果を更新*/
}
return MaxSun;
}
明らかに、総当たり法では 3 つの for ループが使用され、アルゴリズムの時間計算量は O(n
) になります。これはもちろん最も愚かなアルゴリズムですが、データが非常に大きい場合は、たとえ死ぬほど計算されたとしても、 for ループの 3 番目の層がはっきりとわかります j が追加されるたびに部分系列の合計を再度計算する必要があるため、j-1 の結果を使用しないのはなぜでしょうか?つまり、j-1 の結果を保存します。ステップ j の結果を計算するときは、ステップ j-1 に基づいて a[j] を加算するだけで済みます。したがって、アルゴリズム 2 が存在します。
アルゴリズム 2:
#include
int Find_Maxsun2(int*a, int n);
int main(){
int n, i;
int a[100];
cin >>
cout << "数値を入力してください:" <
cout << Find_Maxsun2(a, n) << endl;
return 0;
}
int Find_Maxsun2(int*a, int n){
int i, j, NewSum = 0 , MaxSum= 0;
for (i = 0; i
for (j = i; j NewSum += a[j]; /* j-1 条件で毎回 NewSum を更新します*/
if (NewSum>MaxSum) /*MaxSum を更新します*/
MaxSum = NewSum;
}
}
return MaxSum;
}
このアルゴリズムは 1 より賢く、アルゴリズムの複雑さは O(n
2
アルゴリズム 3:
アルゴリズム 3 は分割と征服の考え方を使用します。基本的な考え方は自明です。最初に分割してから征服し、問題を小さな問題に分解し、次に解決する小さな問題を合計します。 2 つに分割し、次に最大のサブシーケンスを左側、右側、または境界を越えて配置します。 基本的な考え方は次のとおりです。 ステップ 1: 元のシーケンスを 2 つに分割し、左のシーケンスと右のシーケンスに分けます。
ステップ 2: サブシーケンス S left と S right を再帰的に見つけます。
パート 3: 中心線から両側に向かってスキャンして、中心線と S を横切る最大のサブシーケンスを見つけます。
ステップ 4: S=max{S 左、S 中央、S 右} を見つけます。
コードは次のように実装されます:#include
名前空間 std を使用;
int Find_MaxSum3(int*a,int low,int high);
int Max(int a,int b,int c);
int main(){
int n, i;
int a[100];
cin >> n;
cout cin >> a[i];
cout return 0;
}
int Find_MaxSum3(int*a,int low,int high){
int MaxSum = 0, MidSum, LeftSum, RightSum,i;
MidSum = 0;
if (low == high){ /*終了条件recursion* /
if (a[low] > 0)
return a[low];
else
return 0;
}
int mid = (low + high) // 分の中間点を見つける
; LeftSum = Find_MaxSum3 (a, low, middle); /*左のシーケンスの最大合計を再帰的に求めます*/
RightSum = Find_MaxSum3(a, mid + 1, high); /*右のシーケンスの最大のサブシーケンスの合計を再帰的に求めます*/
/*次に、中間の境界を越えるシーケンスの最大合計を見つけることができます*/
int NewLeft = 0,Max_BorderLeft=0, NewRight = 0,Max_BorderRight=0;
for (i = Mid; i >= low; i --){ /*左をスキャンして最大合計を見つけます*/
NewLeft += a[i];
if (NewLeft > Max_BorderLeft)
Max_BorderLeft = NewLeft;
}
for (i = mid + 1; i NewRight+=a[i];
if (NewRight >= Max_BorderRight)
Max_BorderRight = NewRight;
}
MidSum = Max_BorderRight + Max_BorderLeft;
return Max(LeftSum, MidSum, RightSum) ; /*ルールの結果を返します*/
}
int Max(int a, int b, int c){ /*3 つの中で最大の数値を見つけます*/
if ( a>= b&&a >= c)
return a;
if (b >= a&&b >= c)
return b;
if (c >= b&&c>=a)
return c;
}
T(1)=1;
T(n)=2T(n/2)+O(n);
=2
kT(n/2k)+kO(n)=2kT(1)+kO(n) (n=2k)=n+nlogn=O(ンログン);
このアルゴリズムは非常に優れていますが、最速のアルゴリズムではありません。
アルゴリズム 4:
アルゴリズム 4 はオンライン処理と呼ばれます。これは、データが読み込まれるたびに、時間内に処理され、得られた結果が現在読み込まれているデータに当てはまります。つまり、アルゴリズムはどの位置でも正しい解を与えることができ、アルゴリズムは次のことを行うことができます。読みながら正しい解決策を見つけてください。#include
名前空間 std を使用;
int Find_MaxSum4(int*a, int n);
int main(){
int n, i;
int a[100];
cin >>
cout << "数値を入力してください:" <
cout << Find_MaxSum4(a,n) << endl;
return 0;
}
int Find_MaxSum4(int*a, int n){
int i, NewSum = 0, MaxSum = 0;
for (i = 0; i
if (MaxSum
if (NewSum NewSum = 0;
}
return MaxSum;
}
このアルゴリズムは、for ループを 1 つだけ使用して、読み取ったデータを 1 つずつスキャンします。同じ問題を解決するためのアルゴリズムは大きく異なります。重要な中間結果をコンピューターに記憶させて、計算の繰り返しを回避します。
http://www.bkjia.com/PHPjc/1044670.html

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











PHPでは、Password_hashとpassword_verify関数を使用して安全なパスワードハッシュを実装する必要があり、MD5またはSHA1を使用しないでください。 1)password_hashセキュリティを強化するために、塩値を含むハッシュを生成します。 2)password_verifyハッシュ値を比較して、パスワードを確認し、セキュリティを確保します。 3)MD5とSHA1は脆弱であり、塩の値が不足しており、最新のパスワードセキュリティには適していません。

PHPタイプは、コードの品質と読みやすさを向上させるためのプロンプトがあります。 1)スカラータイプのヒント:php7.0であるため、基本データ型は、int、floatなどの関数パラメーターで指定できます。 3)ユニオンタイプのプロンプト:PHP8.0であるため、関数パラメーターまたは戻り値で複数のタイプを指定することができます。 4)Nullable Typeプロンプト:null値を含めることができ、null値を返す可能性のある機能を処理できます。

PHPは主に手順プログラミングですが、オブジェクト指向プログラミング(OOP)もサポートしています。 Pythonは、OOP、機能、手続き上のプログラミングなど、さまざまなパラダイムをサポートしています。 PHPはWeb開発に適しており、Pythonはデータ分析や機械学習などのさまざまなアプリケーションに適しています。

PHPで前処理ステートメントとPDOを使用すると、SQL注入攻撃を効果的に防ぐことができます。 1)PDOを使用してデータベースに接続し、エラーモードを設定します。 2)準備方法を使用して前処理ステートメントを作成し、プレースホルダーを使用してデータを渡し、メソッドを実行します。 3)結果のクエリを処理し、コードのセキュリティとパフォーマンスを確保します。

PHPとPythonには独自の利点と短所があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1.PHPは、大規模なWebアプリケーションの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンスと機械学習の分野を支配しています。

PHPはMySQLIおよびPDO拡張機能を使用して、データベース操作とサーバー側のロジック処理で対話し、セッション管理などの関数を介してサーバー側のロジックを処理します。 1)MySQLIまたはPDOを使用してデータベースに接続し、SQLクエリを実行します。 2)セッション管理およびその他の機能を通じて、HTTPリクエストとユーザーステータスを処理します。 3)トランザクションを使用して、データベース操作の原子性を確保します。 4)SQLインジェクションを防ぎ、例外処理とデバッグの閉鎖接続を使用します。 5)インデックスとキャッシュを通じてパフォーマンスを最適化し、読みやすいコードを書き、エラー処理を実行します。

PHPは動的なWebサイトを構築するために使用され、そのコア関数には次のものが含まれます。1。データベースに接続することにより、動的コンテンツを生成し、リアルタイムでWebページを生成します。 2。ユーザーのインタラクションを処理し、提出をフォームし、入力を確認し、操作に応答します。 3.セッションとユーザー認証を管理して、パーソナライズされたエクスペリエンスを提供します。 4.パフォーマンスを最適化し、ベストプラクティスに従って、ウェブサイトの効率とセキュリティを改善します。

PHPはWeb開発と迅速なプロトタイピングに適しており、Pythonはデータサイエンスと機械学習に適しています。 1.PHPは、単純な構文と迅速な開発に適した動的なWeb開発に使用されます。 2。Pythonには簡潔な構文があり、複数のフィールドに適しており、強力なライブラリエコシステムがあります。
