找到在給定約束條件下,透過N次操作從字串'S'中刪除N個字元後的值
字串的使用規格是什麼?
解決涉及給定字串S的特定挑戰。字串S僅包含小寫英文字母,並且在刪除字元時必須遵循一定的約束。
給定的限制是 -
字串S中有小寫英文字母
只有在字串中出現多次的字元才能刪除。
只能刪除連續出現的字元。以下步驟可用於從字串 S 中刪除字元 -
在迭代字串 S 時尋找所有出現多次的字元。透過對每個字元再次迭代字串 S 來尋找所有連續出現的字元。
如果字元連續出現的次數大於或等於迭代次數,則刪除前 N 個出現的字元。
繼續執行步驟 2 和 3,直到完成所有迭代。
最後,透過傳回最終的字串S,可以發現經過N次操作去除N個字元後的字串的值。
文法
本主題是一個編碼問題,涉及透過對給定字串執行一定數量的操作來操縱該字串。在每次操作中,刪除字串中最常見的字符,並更新每個剩餘字符的頻率。執行N次操作後,透過對剩餘每個字元的頻率進行平方並求和來計算字串的最終值。這個問題的目標是編寫一個程序,以字串和數字 N 作為輸入,並根據給定的約束執行 N 次操作後輸出字串的最終值。
下面是函數的語法,該函數在 N 次操作後找到值,以在給定的約束下刪除字串 S 的 N 個字元 -
int findvalueafterNoperations(int n, string s) { int len = s.length(); int freq[26] = {0}; for (int i = 0; i < len; i++) { freq[s[i] - 'a']++; } sort(freq, freq + 26, greater<int>()); for (int i = 0; i < n; i++) { freq[0]--; sort(freq, freq + 26, greater<int>()); } int value = 0; for (int i = 0; i < 26; i++) { value += freq[i] * freq[i]; } return value; }
此函數接受兩個參數 -
n - 表示要執行的運算元的整數。
s - 表示輸入字串的字串。
此函數首先使用陣列計算輸入字串中每個字元的頻率。然後將此頻率數組按降序排序並執行 N 次操作,其中每次操作中減少最常見字元的頻率並再次對頻率數組進行排序。
最後,函數透過對排序頻率數組中每個字元的頻率平方求和來計算字串的值,並將其作為整數傳回。
演算法
經過N次字元移除過程後,演算法在以下限制下計算字串的值。輸入由數字 N 和字串 S 組成。
第 1 步 - 使用陣列決定輸入字串中每個字元的頻率。
步驟 2 - 降序排列此頻率陣列。
第3步 - 執行N次操作,每次操作都會降低頻率數組中出現頻率最高的字元的頻率。
第 4 步 - 重新排列頻率陣列。
第 5 步 - 將排序後的頻率數組中每個字元的頻率平方相加,以決定字串的值。
第 6 步 - 經過 N 次運算後,字串的值是其平方和。
該技術之所以有效,是因為問題要求從輸入字串 S 中刪除 N 個字符,這就像執行 N 次操作,其中每次操作都會刪除字串中最常見的字符一次。由於任務的限制,我們無法真正從字串中刪除字符,因此我們必須透過在每次操作中降低頻率數組中最常見字符的頻率來模擬此操作。
遵循的方法
方法 1
使用程式碼初始化樣本字串S和各種操作N。在循環執行每個操作後,大於下一個字元的初始字元將被刪除。如果沒有刪除,則最後一個字元將被刪除。所有操作結束後,它會列印字串的最終值。
這裡,程式碼假設 N 小於或等於字串 S 的長度。如果 N 長於 S,則程式碼將無法如預期運作。
範例 1
#include <iostream> #include <string> using namespace std; int main(){ string S = "abcdefg"; int N = 3; for (int l = 1; l <= N; l++) { int p=0; while(p<S.length()- 1) { if(S[p]>S[p+1]) { S.erase(p, 1); break; } p++; } if(p==S.length()- 1) { S.erase(p, 1); } } cout<< S << endl; return 0 ; }
輸出
a b c d
方法2
在此程式碼中,首先使用陣列確定輸入字串中每個字元的頻率。接下來我們執行 N 次操作,每次操作中最常見字元的頻率遞減,並再次對頻率數組進行排序。接下來,我們按降序對這個頻率數組進行排序。
字串的值最終是透過將排序後的頻率數組中每個字元的頻率平方相加來確定。
範例 2
#include <iostream> #include <algorithm> #include <string> using namespace std; int main(){ // Given values int n = 3; string s = "abcabc"; int len = s.length(); int freq[26] = {0}; for (int i = 0; i < len; i++) { freq[s[i] - 'a']++; } sort(freq, freq + 26, greater<int>()); for (int i = 0; i < n; i++) { freq[0]--; sort(freq, freq + 26, greater<int>()); } int value = 0; for (int i = 0; i < 26; i++) { value += freq[i] * freq[i]; } cout << "Value of string after " << n << " operations: " << value << endl; return 0; }
輸出
Value of string after 3 operations: 3
結論
綜上所述,我們可以使用直接技術在 N 次運算後取得值,從而在上述限制下從字串「S」中消除 N 個字元。首先,讓我們初始化頻率數組來追蹤字串中有多少個字元。一旦我們消除了 N 個字符,我們就可以重複從頻率數組中刪除計數最大的字符的過程。這個過程總共可以重複N次。
借助這種方法,我們可以在 N 次操作(包括消除 N 個字元)之後快速確定字串「S」的值。由於方法中存在排序階段,因此此解決方案的時間複雜度為O(N logN),這對於大多數實際應用來說是可以接受的。
以上是找到在給定約束條件下,透過N次操作從字串'S'中刪除N個字元後的值的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

PHP中int型別轉字串的方法詳解在PHP開發中,常會遇到將int型別轉換為字串型別的需求。這種轉換可以透過多種方式實現,本文將詳細介紹幾種常用的方法,並附帶具體的程式碼範例來幫助讀者更好地理解。一、使用PHP內建函數strval()PHP提供了一個內建函數strval(),可以將不同類型的變數轉換為字串類型。當我們需要將int型別轉換為字串型別時,

1.先開啟pycharm,進入到pycharm首頁。 2.然後新建python腳本,右鍵--點選new--點選pythonfile。 3.輸入一段字串,代碼:s="-"。 4.接著需要把字串裡面的符號重複20次,代碼:s1=s*20。5、輸入列印輸出代碼,代碼:print(s1)。 6.最後運行腳本,在最底部會看到我們的回傳值:-就重複了20次。

Go語言是一種強大且靈活的程式語言,它提供了豐富的字串處理功能,包括字串截取。在Go語言中,我們可以使用切片(slice)來截取字串。接下來,將詳細介紹如何在Go語言中截取字串,並附上具體的程式碼範例。一、使用切片截取字串在Go語言中,可以使用切片表達式來截取字串的一部分。切片表達式的語法如下:slice:=str[start:end]其中,s

標題:Golang中判斷字串是否以指定字元結尾的方法在Go語言中,有時候我們需要判斷一個字串是否以特定的字元結尾,這在處理字串時十分常見。本文將介紹如何使用Go語言來實現這項功能,同時提供程式碼範例供大家參考。首先,讓我們來看看Golang中如何判斷一個字串是否以指定字元結尾的方法。 Golang中的字串可以透過索引來取得其中的字符,而字串的長度可

Golang中如何檢查字串是否以特定字元開頭?在使用Golang程式設計時,經常會遇到需要檢查一個字串是否以特定字元開頭的情況。針對這項需求,我們可以使用Golang中的strings套件所提供的函數來實現。接下來將詳細介紹如何使用Golang檢查字串是否以特定字元開頭,並附上具體的程式碼範例。在Golang中,我們可以使用strings套件中的HasPrefix

蘋果快捷指令自動化怎麼刪掉隨著蘋果推出iOS13新系統,用戶可以利用快捷指令(AppleShortcuts)來自訂和自動化各種手機操作,大大提升了用戶的手機使用體驗。然而,有時候我們可能會需要刪除一些不再需要的快速指令。那麼,蘋果快捷指令自動化怎麼刪掉呢?方法一:透過快速指令應用刪除在iPhone或iPad上,開啟「快速指令」應用程式。在底部導覽列中選

解決PHP中16進位轉字串出現中文亂碼的方法在PHP程式設計中,有時候我們會遇到需要將16進位表示的字串轉換為正常的中文字元的情況。然而,在進行這個轉換的過程中,有時會遇到中文亂碼的問題。這篇文章將為您提供解決PHP中16進位轉字串出現中文亂碼的方法,並給出具體的程式碼範例。使用hex2bin()函數進行16進位轉換PHP內建的hex2bin()函數可以將1

PHP字串比對技巧:避免模糊包含表達式在PHP開發中,字串比對是常見的任務,通常用於尋找特定的文字內容或驗證輸入的格式。然而,有時候我們需要避免使用模糊的包含表達式來確保匹配的準確性。本文將介紹一些在PHP中進行字串匹配時避免模糊包含表達式的技巧,並提供具體的程式碼範例。使用preg_match()函數進行精確比對在PHP中,可以使用preg_mat
