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

首頁 後端開發(fā) php教程 計算前綴和後綴對 I

計算前綴和後綴對 I

Jan 09, 2025 am 06:08 AM

Count Prefix and Suffix Pairs I

3042。計算前綴和後綴對 I

難度:簡單

主題:陣列、字串、Trie、滾動雜湊、字串匹配、雜湊函數(shù)

給你一個0索引字串陣列單字。

讓我們定義一個 boolean 函數(shù) isPrefixAndSuffix,它接受兩個字串 str1 和 str2:

  • 如果 str1 是 str2 的前綴1和字尾2,則 isPrefixAndSuffix(str1, str2) 傳回 true,否則傳回 false。

例如,isPrefixAndSuffix("aba", "ababa") 為 true,因為 "aba" 是 "ababa" 的前綴,也是後綴,但 isPrefixAndSuffix("abc", "abcd") 為 false。

傳回一個整數(shù),表示索引對 (i, j) 的 個數(shù) ,使得 i

j,且 isPrefixAndSuffix(words[i], Words[j]) 為 true。

範例1:

  • 輸入:
  • words = ["a","aba","ababa","aa"]
  • 輸出:
  • 4
  • 說明:
  • 在此範例中,計數(shù)的索引對為: i = 0 且 j = 1,因為 isPrefixAndSuffix("a", "aba") 為 true。 i = 0 且 j = 2,因為 isPrefixAndSuffix("a", "ababa") 為 true。 i = 0 且 j = 3,因為 isPrefixAndSuffix("a", "aa") 為 true。 i = 1 且 j = 2,因為 isPrefixAndSuffix("aba", "ababa") 為 true。 因此,答案是4。

範例2:

  • 輸入:
  • words = ["pa","papa","ma","mama"]
  • 輸出:
  • 2
  • 說明:
  • 在此範例中,計數(shù)的索引對為: i = 0 且 j = 1,因為 isPrefixAndSuffix("pa", "papa") 為 true。 i = 2 且 j = 3 因為 isPrefixAndSuffix("ma", "mama") 為 true。 因此,答案是2。

範例 3:

  • 輸入:
  • words = ["abab","ab"]
  • 輸出:
  • 0
  • 解釋:
  • 在此範例中,唯一有效的索引對是 i = 0 和 j = 1,且 isPrefixAndSuffix("abab", "ab") 為 false。 因此,答案是0。

約束:

  • 1 1 words[i] 僅由小寫英文字母組成。

提示:

  1. 迭代所有索引對 (i, j),使得 i 答案是 isPrefixAndSuffix(words[i], Words[j]) == true 的總對數(shù)。

解:

我們需要迭代所有索引對 (i, j),其中 i

讓我們用 PHP 實作這個解決方案:3042。計算前綴和後綴對 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ù)循環(huán)遍歷所有可能的索引對 (i, j),使得 i
    • 它呼叫isPrefixAndSuffix()來檢查words[i]是否既是words[j]的前綴又是後綴。
    • 如果條件為真,則會增加計數(shù)。
  2. isPrefixAndSuffix($str1, $str2):

    • 此輔助函數(shù)檢查 str1 是否既是 str2 的前綴又是後綴。
    • 它使用 substr() 提取 str2 的前綴和後綴,並與 str1 進行比較。
    • 如果兩個條件都為 true,則傳回 true,否則傳回 false。

時間複雜度:

  • 時間複雜度為O(n2 x m),其中n是單字數(shù)組的長度,m是單字數(shù)組的平均長度數(shù)組中的字串。這是由於巢狀循環(huán)和 substr() 操作造成的。

範例輸出:

對於給定的輸入數(shù)組:

  • [“a”,“aba”,“ababa”,“aa”]->輸出:4
  • [“pa”,“papa”,“ma”,“mama”]->輸出:2
  • [“abab”,“ab”]->輸出:0

該解決方案應該在給定的限制內有效地工作。

聯(lián)絡連結

如果您發(fā)現(xiàn)本系列有幫助,請考慮在 GitHub 上給 存儲庫 一個星號或在您最喜歡的社交網絡上分享該帖子? 。您的支持對我來說意義重大!

如果您想要更多類似的有用內容,請隨時關注我:

  • 領英
  • GitHub

  1. 前綴 字串的前綴是從字串開頭開始延伸到字串中任意點的子字串。??

  2. 後綴 字串的後綴是從字串中的任意點開始並延伸到其末尾的子字串。??

以上是計算前綴和後綴對 I的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權的內容,請聯(lián)絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

我如何了解最新的PHP開發(fā)和最佳實踐? 我如何了解最新的PHP開發(fā)和最佳實踐? Jun 23, 2025 am 12:56 AM

TostaycurrentwithPHPdevelopmentsandbestpractices,followkeynewssourceslikePHP.netandPHPWeekly,engagewithcommunitiesonforumsandconferences,keeptoolingupdatedandgraduallyadoptnewfeatures,andreadorcontributetoopensourceprojects.First,followreliablesource

什麼是PHP,為什麼它用於Web開發(fā)? 什麼是PHP,為什麼它用於Web開發(fā)? Jun 23, 2025 am 12:55 AM

PHPbecamepopularforwebdevelopmentduetoitseaseoflearning,seamlessintegrationwithHTML,widespreadhostingsupport,andalargeecosystemincludingframeworkslikeLaravelandCMSplatformslikeWordPress.Itexcelsinhandlingformsubmissions,managingusersessions,interacti

如何設置PHP時區(qū)? 如何設置PHP時區(qū)? Jun 25, 2025 am 01:00 AM

tosetTherightTimeZoneInphp,restate_default_timezone_set()functionAtthestArtofyourscriptWithavalIdidentIdentifiersuchas'america/new_york'.1.usedate_default_default_timezone_set_set()

我如何驗證PHP中的用戶輸入以確保其符合某些標準? 我如何驗證PHP中的用戶輸入以確保其符合某些標準? Jun 22, 2025 am 01:00 AM

TovalidateuserinputinPHP,usebuilt-invalidationfunctionslikefilter_var()andfilter_input(),applyregularexpressionsforcustomformatssuchasusernamesorphonenumbers,checkdatatypesfornumericvalueslikeageorprice,setlengthlimitsandtrimwhitespacetopreventlayout

編寫清潔和可維護的PHP代碼的最佳實踐是什麼? 編寫清潔和可維護的PHP代碼的最佳實踐是什麼? Jun 24, 2025 am 12:53 AM

寫乾淨、易維護的PHP代碼關鍵在於清晰命名、遵循標準、合理結構、善用註釋和可測試性。 1.使用明確的變量、函數(shù)和類名,如$userData和calculateTotalPrice();2.遵循PSR-12標準統(tǒng)一代碼風格;3.按職責拆分代碼結構,使用MVC或Laravel式目錄組織;4.避免麵條式代碼,將邏輯拆分為單一職責的小函數(shù);5.在關鍵處添加註釋並撰寫接口文檔,明確參數(shù)、返回值和異常;6.提高可測試性,採用依賴注入、減少全局狀態(tài)和靜態(tài)方法。這些做法提升代碼質量、協(xié)作效率和後期維護便利性。

什麼是php(serialize(),Unserialize())中的數(shù)據序列化? 什麼是php(serialize(),Unserialize())中的數(shù)據序列化? Jun 22, 2025 am 01:03 AM

thephpfunctionserize()andunSerialize()redustoconvertComplexdatStructDestoresToroStoroStoroSandaBackagagain.1.Serialize()

如何將PHP代碼嵌入HTML文件中? 如何將PHP代碼嵌入HTML文件中? Jun 22, 2025 am 01:00 AM

可以將PHP代碼嵌入HTML文件中,但需確保文件以.php為擴展名,以便服務器能正確解析。使用標準的標籤包裹PHP代碼,可在HTML中任意位置插入動態(tài)內容。此外,可在同一文件中多次切換PHP與HTML,實現(xiàn)條件渲染等動態(tài)功能。務必注意服務器配置及語法正確性,避免因短標籤、引號錯誤或遺漏結束標籤導致問題。

如何使用PHP執(zhí)行SQL查詢? 如何使用PHP執(zhí)行SQL查詢? Jun 24, 2025 am 12:54 AM

Yes,youcanrunSQLqueriesusingPHP,andtheprocessinvolveschoosingadatabaseextension,connectingtothedatabase,executingqueriessafely,andclosingconnectionswhendone.Todothis,firstchoosebetweenMySQLiorPDO,withPDObeingmoreflexibleduetosupportingmultipledatabas

See all articles