検索
ホームページバックエンド開発PHPチュートリアル固有の長さの非インドローム部分配列

Unique Length-alindromic Subsequences

1930年。固有の長さ 3 の回文サブシーケンス

難易度:

トピック: ハッシュ テーブル、文字列、ビット操作、プレフィックス合計

文字列 s を指定すると、s の部分列である長さ 3 の一意の回文の数を返します。

同じサブシーケンスを取得する方法が複数ある場合でも、カウントされるのは 1 回だけであることに注意してください。

回文は、前から見ても後ろから読んでも同じ文字列です。

文字列の

サブシーケンスは、残りの文字の相対的な順序を変更せずに、一部の文字 (なしの場合も可) が削除された元の文字列から生成された新しい文字列です。

    たとえば、「ace」は「abcde」の部分列です。

例 1:

  • 入力: s = "aabca"
  • 出力: 3
  • 説明: 長さ 3 の 3 つの回文部分列は次のとおりです。
      「aba」 (「aabca」のサブシーケンス)
    • "aaa" ("aabca" の部分列)
    • "aca" ("aabca" のサブシーケンス)

例 2:

  • 入力: s = "adc"
  • 出力: 0
  • 説明: 「adc」には長さ 3 の回文部分列がありません。

例 3:

  • 入力: s = "bbcbaba"
  • 出力: 4
  • 説明: 長さ 3 の 4 つの回文部分列は次のとおりです。
      「bbb」 (「bbcbaba」のサブシーケンス)
    • 「bcb」 (「bbcbaba」のサブシーケンス)
    • 「bab」 (「bbcbaba」のサブシーケンス)
    • 「aba」 (「bbcbaba」のサブシーケンス)

制約:

    3 5 s は英小文字のみで構成されます。

ヒント:

    長さ 3 の回文文字列の最大数はいくつですか?
  1. 特定の位置の左側に表示された文字を追跡するにはどうすればよいですか?

解決策:

接頭辞と接尾辞の文字追跡を活用する効率的なアルゴリズムを使用して、有効な回文部分列をすべてカウントできます。

アプローチ

  1. 追跡プレフィックス文字: 配列を使用して、文字列内の各位置の左側にある文字のセットを格納します。これは、文字が回文部分列の最初の部分を形成できるかどうかを効率的にチェックするのに役立ちます。

  2. 追跡サフィックス文字:
    別の配列を使用して、文字列内の各位置の右側にある文字セットを格納します。これは、文字が回文部分列の 3 番目の部分を形成できるかどうかを効率的にチェックするのに役立ちます。

  3. 回文部分列を数える:
    文字列内の各文字を、長さ 3 の回文の中央の文字とみなします。プレフィックス文字とサフィックス文字の有効な組み合わせをすべてチェックして、一意の回文を決定します。

  4. ストア結果:
    ハッシュ セットを使用して一意の回文サブシーケンスを保存し、重複がないようにします。

このソリューションを PHP で実装してみましょう: 1930。固有の長さ 3 の回文サブシーケンス

<?php /**
 * @param String $s
 * @return Integer
 */
function countPalindromicSubsequence($s) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Test cases
echo countPalindromicSubsequence("aabca") . PHP_EOL; // Output: 3
echo countPalindromicSubsequence("adc") . PHP_EOL;   // Output: 0
echo countPalindromicSubsequence("bbcbaba") . PHP_EOL; // Output: 4
?>

説明:

  1. プレフィックス配列:

    • 位置 i の各文字について、prefix[i] にはインデックス i より前に出現したすべての個別の文字が格納されます。
  2. サフィックス配列:

    • 位置 i の各文字について、suffix[i] にはインデックス i の後に出現するすべての個別の文字が格納されます。
  3. 中央の文字:

    • 各文字を回文の中央と考えてください。中央の文字に一致する接頭辞と接尾辞の文字の組み合わせごとに、長さ 3 の回文を形成します。
  4. ハッシュマップ:

    • 連想配列 ($uniquePalindrome) を使用して一意の回文を保存し、重複がカウントされないようにします。

複雑

  • 時間計算量: O(n)

    • 文字列を 2 回走査して、プレフィックス配列とサフィックス配列を計算します。
    • 3 回目のトラバーサルでは、有効な回文サブシーケンスがチェックされます。
  • 空間の複雑さ: O(n)

    • プレフィックス配列とサフィックス配列の場合。

出力

コードは、指定された例に対して正しい結果を生成します。

  • 入力: "aabca" → 出力: 3
  • 入力: "adc" → 出力: 0
  • 入力: "bbcbaba" → 出力: 4

連絡先リンク

このシリーズが役立つと思われた場合は、GitHub で リポジトリ にスターを付けるか、お気に入りのソーシャル ネットワークで投稿を共有することを検討してください。あなたのサポートは私にとって大きな意味を持ちます!

このような役立つコンテンツがさらに必要な場合は、お気軽にフォローしてください:

  • LinkedIn
  • GitHub

以上が固有の長さの非インドローム部分配列の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
トラフィックの高いウェブサイトのPHPパフォーマンスチューニングトラフィックの高いウェブサイトのPHPパフォーマンスチューニングMay 14, 2025 am 12:13 AM

thesecrettokeepingaphp-poweredwebsterunningsmootlyunderheavyloadinvolvesseveralkeystrategies:1)emform opcodecoduceSciptionexecutiontime、2)aatabasequerycachingwithiThing withiThistolessendavasoload、

PHPでの依存関係注射:初心者向けのコード例PHPでの依存関係注射:初心者向けのコード例May 14, 2025 am 12:08 AM

コードをより明確かつ維持しやすくするため、依存関係が関心(DI)に注意する必要があります。 1)DIは、クラスを切り離すことにより、よりモジュール化されます。2)テストとコードの柔軟性の利便性を向上させ、3)DIコンテナを使用して複雑な依存関係を管理しますが、パフォーマンスの影響と円形の依存関係に注意してください。

PHPパフォーマンス:アプリケーションを最適化することは可能ですか?PHPパフォーマンス:アプリケーションを最適化することは可能ですか?May 14, 2025 am 12:04 AM

はい、最適化されたAphPossibleandessention.1)CachingingusapCutoredatedAtabaseload.2)最適化、効率的なQueries、およびConnectionPooling.3)EnhcodeCodewithBultinctions、Avoididingglobalbariables、およびUsingopcodeching

PHPパフォーマンスの最適化:究極のガイドPHPパフォーマンスの最適化:究極のガイドMay 14, 2025 am 12:02 AM

keyStrategIestsoSificlyvoostphpappliceperformanceare:1)useopcodecachinglikeToreexecutiontime、2)最適化abaseの相互作用とプロペラインデックス、3)3)構成

PHP依存性噴射コンテナ:クイックスタートPHP依存性噴射コンテナ:クイックスタートMay 13, 2025 am 12:11 AM

aphpDependencyInjectionContaineriSATOULTAINATINAGECLASSDEPTINCIES、強化測定性、テスト可能性、および維持可能性。

PHPの依存噴射対サービスロケーターPHPの依存噴射対サービスロケーターMay 13, 2025 am 12:10 AM

SELECT DEPENTENCINGINOFCENT(DI)大規模なアプリケーションの場合、ServicElocatorは小さなプロジェクトまたはプロトタイプに適しています。 1)DIは、コンストラクターインジェクションを通じてコードのテスト可能性とモジュール性を改善します。 2)ServiceLocatorは、センター登録を通じてサービスを取得します。これは便利ですが、コードカップリングの増加につながる可能性があります。

PHPパフォーマンス最適化戦略。PHPパフォーマンス最適化戦略。May 13, 2025 am 12:06 AM

phpapplicationscanbeoptimizedforspeedandEfficiencyby:1)enabingopcacheinphp.ini、2)PreparedStatementswithpordatabasequeriesを使用して、3)LoopswithArray_filterandarray_mapfordataprocessing、4)の構成ngincasaSearverseproxy、5)

PHPメールの検証:電子メールが正しく送信されるようにしますPHPメールの検証:電子メールが正しく送信されるようにしますMay 13, 2025 am 12:06 AM

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl

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

Video Face Swap

Video Face Swap

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

ホットツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール