問題陳述 1071. 字串的最大公約數
對於兩個字串s 和t,當且僅當s = t + t + t + ... + t + t (即t 與自身連接一次或多次)時,我們才說「t 除s」。
給定兩個字串 str1 和 str2,傳回最大的字串 x,使得 x 整除 str1 和 str2。
我的思考過程
儘管leetcode將其標記為簡單問題,但我必須承認我發現很難立即想出解決方案。
讓我回顧一下 leetcode 提供的測試案例並透過它們來解釋我的困惑。
測試用例
輸入:str1 = "ABCABC", str2 = "ABC"
輸出:“ABC”輸入:str1 = "ABABAB", str2 = "ABAB"
輸出:“AB”
從問題陳述和測試案例 1 中,我確實確定我們需要輸出最大的字串(“ABC”),連接起來我們可以得到兩個字串。 (預設字串“ABC”=== str2 和“ABC”+“ABC”=== str1)。
但是,查看測試案例 2,我很快意識到我的理解不正確,因為我應該輸出“ABAB”,因為這是我可以創建兩個字串的最長字串。但我開始編寫程式碼並開始製定解決方案。 (菜鳥錯誤?)
失敗/成功的事
我只能訂定一個解決方案:
- 求兩個字串的 GCD。
- 從最小字串的長度迭代到GCD
- 從最小字串中取一個子字串到目前迭代值。
- 如果兩個字串都包含該子字串,則傳回該子字串作為答案。
- 如果沒有找到字串,則傳回「」。
如您所見,對於 str1 包含 str2 但還包含一些其他附加字元的字串,我的解決方案失敗了。違反了 s = t + t + ... + t + t 的要求。
我必須向neetcode的解決方案尋求協助。我很快就明白我的問題了:
我正在尋找字串長度的 GCD,而不是字串本身。我需要找到一個字串,重複這些字串我可以創建兩個字串而沒有任何剩餘字元。
我意識到為什麼「ABAB」不能作為測試案例 2 的答案:
我們需要找到 x 以便將兩個字串均分。因此,以“ABAB”作為字串,您可以完全創建 str2,但對於 str1,您最終會得到“ABABABAB”。你最終會得到 2 個多餘的“AB”,並且不能說你完全透過組合 x 創建了 str1。
「ABAB」長度為 4 和「ABABAB」長度為 6。2 個字串的 GCD = 2。因此輸出需要是長度為 2 的字串。
輸出
時間與空間複雜度
時間複雜度:
在最壞的情況下,我們迭代Min(str1,str2) 並且需要重新建立str1 和str2,這樣總時間將是(str1.length + str2.length)複雜度將為O(min(str1,str2) * (str1.length + str2.length))空間複雜度:
O(1),因為我們不需要任何額外的空間。以上是Leetcode:字串的最大公約數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

本教程向您展示瞭如何將自定義的Google搜索API集成到您的博客或網站中,提供了比標準WordPress主題搜索功能更精緻的搜索體驗。 令人驚訝的是簡單!您將能夠將搜索限制為Y

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

本文系列在2017年中期進行了最新信息和新示例。 在此JSON示例中,我們將研究如何使用JSON格式將簡單值存儲在文件中。 使用鍵值對符號,我們可以存儲任何類型的

利用輕鬆的網頁佈局:8 ESTISSEL插件jQuery大大簡化了網頁佈局。 本文重點介紹了簡化該過程的八個功能強大的JQuery插件,對於手動網站創建特別有用

核心要點 JavaScript 中的 this 通常指代“擁有”該方法的對象,但具體取決於函數的調用方式。 沒有當前對象時,this 指代全局對象。在 Web 瀏覽器中,它由 window 表示。 調用函數時,this 保持全局對象;但調用對象構造函數或其任何方法時,this 指代對象的實例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。這些方法使用給定的 this 值和參數調用函數。 JavaScript 是一門優秀的編程語言。幾年前,這句話可

jQuery是一個很棒的JavaScript框架。但是,與任何圖書館一樣,有時有必要在引擎蓋下發現發生了什麼。也許是因為您正在追踪一個錯誤,或者只是對jQuery如何實現特定UI感到好奇

該帖子編寫了有用的作弊表,參考指南,快速食譜以及用於Android,BlackBerry和iPhone應用程序開發的代碼片段。 沒有開發人員應該沒有他們! 觸摸手勢參考指南(PDF)是Desig的寶貴資源


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

Dreamweaver CS6
視覺化網頁開發工具

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