ホームページ バックエンド開発 PHPの問題 PHPで一意の文字列を見つける方法

PHPで一意の文字列を見つける方法

Mar 29, 2023 am 10:11 AM

PHP は、動的な Web サイトや Web アプリケーションの開発に広く使用されている、非常に人気のある Web プログラミング言語です。開発プロセスでは、一意の文字列を検索するなど、文字列を処理することが必要になることがよくあります。この記事では、PHP を使用して一意の文字列を検索する強力なプログラムを作成する方法を紹介します。

1. 非繰り返し文字列とは

コンピューター サイエンスでは、非繰り返し文字列とは、文字列内に繰り返し文字がない部分文字列を指します。たとえば、文字列「hello world」の場合、繰り返されない部分文字列は「hel」、「helo」、「hell」、「hello」、「wor」、「world」などです。

2. 一意の文字列を見つけるためのアルゴリズム

一意の文字列を見つけるには、文字列を処理するアルゴリズムを使用する必要があります。一般的に使用されるアルゴリズムには、「スライディング ウィンドウ」や「ハッシュ テーブル」などがあります。

  1. スライディング ウィンドウ アルゴリズム

スライディング ウィンドウ アルゴリズムは、O(n) 時間計算量の文字列内で一意の文字列を見つけることができる、非常に効果的な文字列処理アルゴリズムです。

このアルゴリズムの手順は次のとおりです。

1) 文字列の最初の文字をそれぞれ指す、左右の 2 つのポインターを定義します。

2) ハッシュ テーブルを使用して、各文字の出現数を記録します。

3) 繰り返される文字が見つかるまで、右ポインタを右に移動します。

4) 繰り返される文字がなくなるまで、左ポインタを右に移動します。

5) 右ポインタが文字列の末尾に到達するまで、手順 3 と 4 を繰り返します。

6) それぞれの非繰り返し部分文字列の長さを計算し、最長の非繰り返し部分文字列を見つけます。

次は、このアルゴリズムの PHP 実装です:

function findLongestSubstring($str){

$n = strlen($str);
$set = array();
$ans = $i = $j = 0;
while ($i < $n && $j < $n) {
    if (!isset($set[$str[$j]])) {
        $set[$str[$j++]] = true;
        $ans = max($ans, $j - $i);
    } else {
        unset($set[$str[$i++]]);
    }
}
return $ans;
ログイン後にコピー

}

  1. ハッシュ テーブル アルゴリズム

ハッシュ テーブル アルゴリズムは、高速検索に使用されるデータ構造であり、ハッシュ テーブルに要素が存在するかどうかを迅速に見つけることができます。このアルゴリズムの実装アイデアは次のとおりです。

1) ハッシュ テーブルを使用して、文字が出現する位置を保存します。

2) 文字列を走査し、文字がハッシュ テーブルにない場合はハッシュ テーブルに追加し、そうでない場合は文字の位置情報を更新します。

3) 非反復部分文字列の開始位置と終了位置を記録します。

4) 最長の部分文字列の長さを更新します。

5) 最長の部分文字列の長さを返します。

次は、このアルゴリズムの PHP 実装です:

function findLongestSubstring($str){

$n = strlen($str);
$map = array();
for ($i = $j = $ans = 0; $j < $n; $j++) {
    if (isset($map[$str[$j]])) {
        $i = max($map[$str[$j]], $i);
    }
    $ans = max($ans, $j - $i + 1);
    $map[$str[$j]] = $j + 1;
}
return $ans;
ログイン後にコピー

}

3. テスト プログラム

上記のアルゴリズムが正しいことを検証するために、テスト プログラムを作成しました。このプログラムは文字列をランダムに生成し、上記の 2 つのアルゴリズムを使用して最長の非反復部分文字列を見つけることができます。プログラムをループで実行して、アルゴリズムの精度と実行時間を検証できます。

以下はテスト プログラムの PHP コードです:

function randomString($length = 10) {

$str = '';
$chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
for ($i = 0; $i < $length; $i++) {
    $str .= $chars[rand(0, strlen($chars) - 1)];
}
return $str;
ログイン後にコピー

}

$N = 5 ;
for ($i = 0; $i < $N; $i ) {

$str = randomString(100000);
$start = microtime();
$ans1 = findLongestSubstring($str);
$end = microtime();
$time1 = ($end - $start) * 1000;

$start = microtime();
$ans2 = findLongestSubstring($str);
$end = microtime();
$time2 = ($end - $start) * 1000;

printf("Test case %d: %s\n", $i + 1, $str);
printf("滑动窗口算法: %d (%.3fms)\n", $ans1, $time1);
printf("哈希表算法: %d (%.3fms)\n", $ans2, $time2);
ログイン後にコピー

}

4. 概要

この記事では、次の方法を紹介します。 PHP を使用して非反復部分文字列を見つけるプログラムを作成し、スライディング ウィンドウ アルゴリズムとハッシュ テーブル アルゴリズムという 2 つの一般的に使用されるアルゴリズムを導入します。スライディング ウィンドウ アルゴリズムは、時間計算量が O(n) の効率的なアルゴリズムであり、大規模なデータの処理に適しています。ハッシュ テーブル アルゴリズムは、スペース利用の点で制御しやすいですが、時間計算量は高くなります。プログラム内のテスト手順は、現在のシナリオに最適なアルゴリズムを選択するために、アルゴリズムの実行時間と正確さを検証するのに役立ちます。

以上がPHPで一意の文字列を見つける方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

PHPアレイの重複排除のためのベストプラクティスは何ですか PHPアレイの重複排除のためのベストプラクティスは何ですか Mar 03, 2025 pm 04:41 PM

この記事では、効率的なPHPアレイ重複排除について説明します。 Array_unique()などの組み込み関数をカスタムハッシュマップアプローチと比較し、配列のサイズとデータ型に基づいてパフォーマンスのトレードオフを強調します。 最適な方法は、プロビリに依存します

PHPアレイの重複排除は、パフォーマンスの損失について考慮する必要がありますか? PHPアレイの重複排除は、パフォーマンスの損失について考慮する必要がありますか? Mar 03, 2025 pm 04:47 PM

この記事では、PHPアレイの重複排除を分析し、素朴なアプローチ(O(n²))のパフォーマンスボトルネックを強調しています。 カスタム関数、splobjectStorage、およびハッシュセットの実装を使用して、array_unique()を使用して効率的な代替案を調査し、達成します

PHPアレイの重複排除は、キー名の一意性を利用できますか? PHPアレイの重複排除は、キー名の一意性を利用できますか? Mar 03, 2025 pm 04:51 PM

この記事では、Keyの一意性を使用してPHPアレイ重複排除について説明します。 直接的な重複除去方法ではありませんが、キーユニークネスを活用することで、キーに値をマッピングして重複を上書きすることにより、一意の値を持つ新しい配列を作成できます。 このAP

PHPにメッセージキュー(rabbitmq、redis)を実装する方法は? PHPにメッセージキュー(rabbitmq、redis)を実装する方法は? Mar 10, 2025 pm 06:15 PM

この記事では、RabbitMQとRedisを使用してPHPでメッセージキューを実装する詳細を示します。 それは、それらのアーキテクチャ(AMQP対インメモリ)、機能、および信頼性メカニズム(確認、トランザクション、永続性)を比較します。デザインのベストプラクティス、エラー

最新のPHPコーディング基準とベストプラクティスは何ですか? 最新のPHPコーディング基準とベストプラクティスは何ですか? Mar 10, 2025 pm 06:16 PM

この記事では、PSRの推奨事項(PSR-1、PSR-2、PSR-4、PSR-12)に焦点を当てた現在のPHPコーディング基準とベストプラクティスを検証します。 一貫したスタイリング、意味のある命名、EFFを通じてコードの読みやすさと保守性を改善することを強調しています

PHP拡張機能とPECLを使用するにはどうすればよいですか? PHP拡張機能とPECLを使用するにはどうすればよいですか? Mar 10, 2025 pm 06:12 PM

この記事では、PHP拡張機能のインストールとトラブルシューティングの詳細で、PECLに焦点を当てています。 インストール手順(検索、ダウンロード/コンパイル、サーバーの再起動、再起動)、トラブルシューティングテクニック(ログのチェック、インストールの確認、

PHPアレイの重複排除のための最適化手法は何ですか PHPアレイの重複排除のための最適化手法は何ですか Mar 03, 2025 pm 04:50 PM

この記事では、大規模なデータセットのPHPアレイ重力化の最適化について説明します。 Array_unique()、array_flip()、splobjectStorage、事前ソートなどの手法を調べ、効率を比較します。 大規模なデータセットの場合、チャンク、データブを示唆しています

リフレクションを使用してPHPコードを分析および操作する方法は? リフレクションを使用してPHPコードを分析および操作する方法は? Mar 10, 2025 pm 06:12 PM

この記事では、PHPの反射APIについて説明し、クラス、方法、およびプロパティのランタイム検査と操作を可能にします。 一般的なユースケース(ドキュメンテーション生成、ORM、依存関係注入)とパフォーマンスオーバーヘアに対する注意の詳細

See all articles