ホームページ >バックエンド開発 >PHPチュートリアル >固有の長さの非インドローム部分配列
1930年。固有の長さ 3 の回文サブシーケンス
難易度: 中
トピック: ハッシュ テーブル、文字列、ビット操作、プレフィックス合計
文字列 s を指定すると、s の部分列である長さ 3 の一意の回文の数を返します。
同じサブシーケンスを取得する方法が複数ある場合でも、カウントされるのは 1 回だけであることに注意してください。
回文は、前から見ても後ろから読んでも同じ文字列です。
文字列のサブシーケンスは、残りの文字の相対的な順序を変更せずに、一部の文字 (なしの場合も可) が削除された元の文字列から生成された新しい文字列です。
例 1:
例 2:
例 3:
制約:
ヒント:
解決策:
接頭辞と接尾辞の文字追跡を活用する効率的なアルゴリズムを使用して、有効な回文部分列をすべてカウントできます。アプローチ
追跡プレフィックス文字:
配列を使用して、文字列内の各位置の左側にある文字のセットを格納します。これは、文字が回文部分列の最初の部分を形成できるかどうかを効率的にチェックするのに役立ちます。
追跡サフィックス文字:
別の配列を使用して、文字列内の各位置の右側にある文字セットを格納します。これは、文字が回文部分列の 3 番目の部分を形成できるかどうかを効率的にチェックするのに役立ちます。
回文部分列を数える:
文字列内の各文字を、長さ 3 の回文の中央の文字とみなします。プレフィックス文字とサフィックス文字の有効な組み合わせをすべてチェックして、一意の回文を決定します。
ストア結果:
ハッシュ セットを使用して一意の回文サブシーケンスを保存し、重複がないようにします。
このソリューションを 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 ?>
プレフィックス配列:
サフィックス配列:
中央の文字:
ハッシュマップ:
時間計算量: O(n)
空間の複雑さ: O(n)
コードは、指定された例に対して正しい結果を生成します。
連絡先リンク
このシリーズが役立つと思われた場合は、GitHub で リポジトリ にスターを付けるか、お気に入りのソーシャル ネットワークで投稿を共有することを検討してください。あなたのサポートは私にとって大きな意味を持ちます!
このような役立つコンテンツがさらに必要な場合は、お気軽にフォローしてください:
以上が固有の長さの非インドローム部分配列の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。