国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

ホームページ バックエンド開(kāi)発 PHPチュートリアル プレフィックスとサフィックスのペアを數(shù)える I

プレフィックスとサフィックスのペアを數(shù)える I

Jan 09, 2025 am 06:08 AM

Count Prefix and Suffix Pairs I

3042。プレフィックスとサフィックスのペアを數(shù)える I

難易度: 簡(jiǎn)単

トピック: 配列、文字列、トライ、ローリング ハッシュ、文字列マッチング、ハッシュ関數(shù)

インデックスが 0 の 文字列配列ワードが與えられます。

2 つの文字列 str1 と str2 を取る boolean 関數(shù) isPrefixAndSuffix を定義しましょう。

  • isPrefixAndSuffix(str1, str2) は、str1 が str2 のプレフィックス1 とサフィックス2両方である場(chǎng)合に true を返し、それ以外の場(chǎng)合は false を返します。

たとえば、「aba」は「ababa」の接頭辭であり接尾辭でもあるため、isPrefixAndSuffix("aba", "ababa") は true ですが、isPrefixAndSuffix("abc", "abcd") は false です。

i 數(shù) を表す整數(shù)を返します。 j、および isPrefixAndSuffix(words[i], Words[j]) は true です。

例 1:

  • 入力: 単語(yǔ) = ["a","aba","ababa","aa"]
  • 出力: 4
  • 説明: この例では、カウントされるインデックスのペアは次のとおりです。 isPrefixAndSuffix("a", "aba") が true であるため、i = 0 および j = 1。 isPrefixAndSuffix("a", "ababa") が true であるため、i = 0 および j = 2。 isPrefixAndSuffix("a", "aa") が true であるため、i = 0 および j = 3。 isPrefixAndSuffix("aba", "ababa") が true であるため、i = 1 および j = 2 となります。 したがって、答えは 4.

例 2:

  • 入力: 単語(yǔ) = ["pa","papa","ma","mama"]
  • 出力: 2
  • 説明: この例では、カウントされるインデックスのペアは次のとおりです。 isPrefixAndSuffix("pa", "papa") が true であるため、i = 0 および j = 1。 isPrefixAndSuffix("ma", "mama") が true であるため、i = 2 および j = 3。 したがって、答えは 2.

例 3:

  • 入力: 単語(yǔ) = ["abab","ab"]
  • 出力: 0
  • 説明: この例では、唯一の有効なインデックス ペアは i = 0 および j = 1 であり、isPrefixAndSuffix("abab", "ab") は false です。 したがって、答えは0です。

制約:

  • 1
  • 1
  • Words[i] は英小文字のみで構(gòu)成されています。

ヒント:

  1. i を確認(rèn)します。
  2. 答えは、isPrefixAndSuffix(words[i], Words[j]) == true となるペアの合計(jì)數(shù)です。

解決策:

すべてのインデックス ペア (i, j) (i

このソリューションを PHP で実裝してみましょう: 3042。プレフィックスとサフィックスのペアを數(shù)える I

<?php
/**
 * @param String[] $words
 * @return Integer
 */
function countPrefixAndSuffixPairs($words) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

/**
 * Function to check if str1 is both a prefix and a suffix of str2
 *
 * @param $str1
 * @param $str2
 * @return bool
 */
function isPrefixAndSuffix($str1, $str2) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Example Test Cases
$words1 = ["a", "aba", "ababa", "aa"];
$words2 = ["pa", "papa", "ma", "mama"];
$words3 = ["abab", "ab"];

echo countPrefixAndSuffixPairs($words1) . "\n";  // Output: 4
echo countPrefixAndSuffixPairs($words2) . "\n";  // Output: 2
echo countPrefixAndSuffixPairs($words3) . "\n";  // Output: 0
?>

説明:

  1. countPrefixAndSuffixPairs($words):

    • この関數(shù)は、i
    • isPrefixAndSuffix() を呼び出して、words[i] が Words[j] の接頭辭と接尾辭の両方であるかどうかを確認(rèn)します。
    • 條件が true の場(chǎng)合、カウントが増加します。
  2. isPrefixAndSuffix($str1, $str2):

    • このヘルパー関數(shù)は、str1 が str2 のプレフィックスとサフィックスの両方であるかどうかをチェックします。
    • substr() を使用して str2 のプレフィックスとサフィックスを抽出し、str1 と比較します。
    • 両方の條件が true の場(chǎng)合は true を返し、それ以外の場(chǎng)合は false を返します。

時(shí)間計(jì)算量:

  • 時(shí)間計(jì)算量は O(n2 x m) です。ここで、n は単語(yǔ)配列の長(zhǎng)さ、m は単語(yǔ)配列の平均長(zhǎng)です。配列內(nèi)の文字列。これは、ネストされたループと substr() 操作が原因です。

出力例:

指定された入力配列の場(chǎng)合:

  • ["a", "aba", "ababa", "aa"] ->出力: 4
  • [「パ」、「パパ」、「マ」、「ママ」] ->出力: 2
  • ["アバブ"、"アブ"] ->出力: 0

このソリューションは、指定された制約內(nèi)で効率的に機(jī)能するはずです。

連絡(luò)先リンク

このシリーズが役立つと思われた場(chǎng)合は、GitHub で リポジトリ にスターを付けるか、お?dú)荬巳毪辘违僵`シャル ネットワークで投稿を共有することを検討してください。あなたのサポートは私にとって大きな意味を持ちます!

このような役立つコンテンツがさらに必要な場(chǎng)合は、お?dú)葺Xにフォローしてください:

  • LinkedIn
  • GitHub

  1. Prefix 文字列の接頭辭は、文字列の先頭から始まり、文字列內(nèi)の任意の點(diǎn)まで続く部分文字列です。??

  2. サフィックス 文字列のサフィックスは、文字列內(nèi)の任意の位置から始まり、その末尾まで続く部分文字列です。??

以上がプレフィックスとサフィックスのペアを數(shù)える Iの詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見(jiàn)つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無(wú)料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無(wú)料のコードエディター

SublimeText3 中國(guó)語(yǔ)版

SublimeText3 中國(guó)語(yǔ)版

中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開(kāi)発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開(kāi)発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

PHPに認(rèn)証と承認(rèn)を?qū)g裝するにはどうすればよいですか? PHPに認(rèn)証と承認(rèn)を?qū)g裝するにはどうすればよいですか? Jun 20, 2025 am 01:03 AM

tosecurelyhandLeauthenticationAndauthorizationInizationInization、followTheSteps:1.LwayShashPasswordswithPassword_hash()andverifyusingpassword_verify()、usepreparedStatementStatementStatementStatementStatementStain、andstoreUserdatain $ _SessionAfterlogin.2.implementRementRementRementRementRementRementRementRole

最新のPHP開(kāi)発とベストプラクティスを最新の狀態(tài)に保つにはどうすればよいですか? 最新のPHP開(kāi)発とベストプラクティスを最新の狀態(tài)に保つにはどうすればよいですか? Jun 23, 2025 am 12:56 AM

postaycurrentwithpdevellyments andbest practices、follow keynewsourceslikephp.netandphpweekly、egagewithcommunitiessonforums andconferences、keeptooling and gradivallyadoptnewfeatures、andreadorcontributeTopensourceprijeprijeprijeptrijeprijeprests.

PHPとは何ですか、そしてなぜそれがWeb開(kāi)発に使用されるのですか? PHPとは何ですか、そしてなぜそれがWeb開(kāi)発に使用されるのですか? Jun 23, 2025 am 12:55 AM

PhpBecamepopularforwebdevelopmentduetoitseaseaseaseaseasease、SeamlessintegrationWithhtml、widespreadhostingsupport、andalargeecosystemincludingframeworkelavelandcmsplatformslikewordspresspressinsinsionsisionsisionsisionsisionsionsionsisionsionsionsisionsisions

PHPタイムゾーンを設(shè)定する方法は? PHPタイムゾーンを設(shè)定する方法は? Jun 25, 2025 am 01:00 AM

tosettherighttimezoneInphp、usedate_default_timezone_set()functionthestthestofyourscriptwithavalididentifiersiersuchas'america/new_york'.1.usedate_default_timezone_set()beforeanydate/timefunctions.2.2.Altertentally、confuturethephp.inifilebyset.

オペレーティングシステム(Windows、MacOS、Linux)にPHPをインストールするにはどうすればよいですか? オペレーティングシステム(Windows、MacOS、Linux)にPHPをインストールするにはどうすればよいですか? Jun 20, 2025 am 01:02 AM

PHPをインストールする方法は、オペレーティングシステムごとに異なります。以下は特定の手順です。1。WindowsユーザーはXAMPPを使用してパッケージをインストールしたり、手動(dòng)で構(gòu)成したり、XAMPPをダウンロードしてインストールしたり、PHPコンポーネントを選択したり、環(huán)境変數(shù)にPHPを追加したりできます。 2。MACOSユーザーは、Homebrewを介してPHPをインストールし、対応するコマンドを?qū)g行してApacheサーバーをインストールして構(gòu)成できます。 3。Linuxユーザー(Ubuntu/Debian)は、APTパッケージマネージャーを使用してソースを更新し、PHPと共通拡張機(jī)能をインストールし、テストファイルを作成してインストールが成功したかどうかを確認(rèn)できます。

PHPでのユーザー入力を検証して、特定の基準(zhǔn)を満たすことを確認(rèn)するにはどうすればよいですか? PHPでのユーザー入力を検証して、特定の基準(zhǔn)を満たすことを確認(rèn)するにはどうすればよいですか? Jun 22, 2025 am 01:00 AM

tovalidateuserinputinphp、usebuilt-validationfunctionslikefilter_var()andfilter_input()、applyRegularexpressionsforcustomformatsusususussusorphoneNumbers、checkdatatypesfornumerueSlikeageorpricepriceprice

session_destroy()を使用してPHPでセッションを破壊するにはどうすればよいですか? session_destroy()を使用してPHPでセッションを破壊するにはどうすればよいですか? Jun 20, 2025 am 01:06 AM

PHPでのセッションを完全に破壊するには、最初にセッションを開(kāi)始するにはSESSION_START()に電話してから、session_destroy()を呼び出してすべてのセッションデータを削除する必要があります。 1。最初にsession_start()を使用して、セッションが開(kāi)始されていることを確認(rèn)します。 2。その後、SESSION_DESTROY()を呼び出してセッションデータをクリアします。 3。オプションですが推奨:グローバル変數(shù)をクリアするための手動(dòng)で$ _Sessionアレイを解除します。 4。同時(shí)に、セッションCookieを削除して、ユーザーがセッション狀態(tài)を保持しないようにします。 5.最後に、破壊後にユーザーのリダイレクトに注意を払い、すぐにセッション変數(shù)を再利用しないでください。そうしないと、セッションを再起動(dòng)する必要があります。これを行うと、ユーザーが殘留情報(bào)を殘さずにシステムを完全に終了することが保証されます。

クリーンで保守可能なPHPコードを書くためのベストプラクティスは何ですか? クリーンで保守可能なPHPコードを書くためのベストプラクティスは何ですか? Jun 24, 2025 am 12:53 AM

清潔で維持しやすいPHPコードを書くための鍵は、標(biāo)準(zhǔn)、合理的な構(gòu)造に従って、コメント、テスト能力を適切に利用する明確な命名にあります。 1。$ userDataやcalculatetotalprice()などの明確な変數(shù)、関數(shù)、クラス名を使用します。 2。PSR-12標(biāo)準(zhǔn)統(tǒng)一コードスタイルに従ってください。 3.責(zé)任に従ってコード構(gòu)造を分割し、MVCまたはLaravelスタイルのカタログを使用して整理します。 4.麺スタイルのコードを避け、単一の責(zé)任でロジックを小さな関數(shù)に分割します。 5.キーポイントにコメントを追加し、インターフェイスドキュメントを書き込み、パラメーター、返品値、例外を明確にします。 6.テスト可能性を改善し、依存関係を採(cǎi)用し、グローバルな狀態(tài)と靜的な方法を減らします。これらのプラクティスは、コードの品質(zhì)、コラボレーション効率、メンテナンス後の容易さを改善します。

See all articles