在字串操作領域,識別模式和提取有意義的子字串是常見任務。一個有趣的問題涉及找到最長的子串,其中沒有相鄰字元是相鄰的英文字母。在本文中,我們將使用 C 深入研究此問題的有效解決方案,並提供清晰的解釋和範例測試案例。
給定一串小寫英文字母,我們需要找到沒有相鄰字元是相鄰英文字母的最長子串的長度。例如字串“abacabx”中,滿足該條件的最長子字串為“abx”,長度為3。
為了解決這個問題,我們可以利用貪心方法。我們將迭代給定的字串並檢查當前字元和前一個字元是否是相鄰的英文字母。如果是,我們將開始一個新的子字串。否則,我們將擴展現有的子字串。透過每當最長子字串的長度超過先前的最大值時就更新它,我們就可以找到想要的結果。
這是解決問題的 C 程式碼 &minus,
#include <iostream> #include <string> using namespace std; int findLongestSubstring(const string& str) { int maxLength = 0; int currentLength = 1; for (int i = 1; i < str.length(); i++) { if (abs(str[i] - str[i - 1]) != 1) { currentLength++; } else { maxLength = max(maxLength, currentLength); currentLength = 1; } } maxLength = max(maxLength, currentLength); return maxLength; } int main() { string inputString = "abacabx"; int longestSubstringLength = findLongestSubstring(inputString); cout << "Longest substring length: " << longestSubstringLength << endl; return 0; }
Longest substring length: 3
函數 findLongestSubstring 接受輸入字串作為參數,並傳回最長的不相鄰英文字母字元的子字串的長度。
我們將 maxLength 和 currentLength 分別初始化為 0 和 1。然後我們從第二個字元開始迭代字串。如果當前字元與前一個字元之間的絕對差不等於 1,則增加 currentLength 以擴展當前子字串。否則,如果當前長度超出先前的最大值,我們將更新 maxLength 並將 currentLength 重設為 1。
最後,我們回傳找到的最大長度。在主函數中,我們提供了一個範例輸入字串“abacabx”,並列印最長子字串的長度。
讓我們考慮範例字串"abacabx"來展示我們的解決方案。
輸入
string inputString = "abacabx";
本例中,沒有相鄰英文字母字元的最長子字串是“abx”,長度為3。
透過採用簡單而有效率的方法,我們成功地解決了使用C 找到最長的不相鄰英文字母子串的問題。理解所提供的程式碼和解釋將使您能夠解決涉及字串操作的類似問題。
以上是最長的子字串,其中相鄰的字元沒有相鄰的英文字母的詳細內容。更多資訊請關注PHP中文網其他相關文章!