搜尋
首頁後端開發C++找到在給定約束條件下,透過N次操作從字串'S'中刪除N個字元後的值

找到在給定約束條件下,透過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中文網其他相關文章!

陳述
本文轉載於:tutorialspoint。如有侵權,請聯絡admin@php.cn刪除
C#vs. C:內存管理和垃圾收集C#vs. C:內存管理和垃圾收集Apr 15, 2025 am 12:16 AM

C#使用自動垃圾回收機制,而C 採用手動內存管理。 1.C#的垃圾回收器自動管理內存,減少內存洩漏風險,但可能導致性能下降。 2.C 提供靈活的內存控制,適合需要精細管理的應用,但需謹慎處理以避免內存洩漏。

超越炒作:評估當今C的相關性超越炒作:評估當今C的相關性Apr 14, 2025 am 12:01 AM

C 在現代編程中仍然具有重要相關性。 1)高性能和硬件直接操作能力使其在遊戲開發、嵌入式系統和高性能計算等領域佔據首選地位。 2)豐富的編程範式和現代特性如智能指針和模板編程增強了其靈活性和效率,儘管學習曲線陡峭,但其強大功能使其在今天的編程生態中依然重要。

C社區:資源,支持和發展C社區:資源,支持和發展Apr 13, 2025 am 12:01 AM

C 學習者和開發者可以從StackOverflow、Reddit的r/cpp社區、Coursera和edX的課程、GitHub上的開源項目、專業諮詢服務以及CppCon等會議中獲得資源和支持。 1.StackOverflow提供技術問題的解答;2.Reddit的r/cpp社區分享最新資訊;3.Coursera和edX提供正式的C 課程;4.GitHub上的開源項目如LLVM和Boost提陞技能;5.專業諮詢服務如JetBrains和Perforce提供技術支持;6.CppCon等會議有助於職業

c#vs. c:每種語言都擅長c#vs. c:每種語言都擅長Apr 12, 2025 am 12:08 AM

C#適合需要高開發效率和跨平台支持的項目,而C 適用於需要高性能和底層控制的應用。 1)C#簡化開發,提供垃圾回收和豐富類庫,適合企業級應用。 2)C 允許直接內存操作,適用於遊戲開發和高性能計算。

繼續使用C:耐力的原因繼續使用C:耐力的原因Apr 11, 2025 am 12:02 AM

C 持續使用的理由包括其高性能、廣泛應用和不斷演進的特性。 1)高效性能:通過直接操作內存和硬件,C 在系統編程和高性能計算中表現出色。 2)廣泛應用:在遊戲開發、嵌入式系統等領域大放異彩。 3)不斷演進:自1983年發布以來,C 持續增加新特性,保持其競爭力。

C和XML的未來:新興趨勢和技術C和XML的未來:新興趨勢和技術Apr 10, 2025 am 09:28 AM

C 和XML的未來發展趨勢分別為:1)C 將通過C 20和C 23標準引入模塊、概念和協程等新特性,提升編程效率和安全性;2)XML將繼續在數據交換和配置文件中佔據重要地位,但會面臨JSON和YAML的挑戰,並朝著更簡潔和易解析的方向發展,如XMLSchema1.1和XPath3.1的改進。

現代C設計模式:構建可擴展和可維護的軟件現代C設計模式:構建可擴展和可維護的軟件Apr 09, 2025 am 12:06 AM

現代C 設計模式利用C 11及以後的新特性實現,幫助構建更靈活、高效的軟件。 1)使用lambda表達式和std::function簡化觀察者模式。 2)通過移動語義和完美轉發優化性能。 3)智能指針確保類型安全和資源管理。

C多線程和並發:掌握並行編程C多線程和並發:掌握並行編程Apr 08, 2025 am 12:10 AM

C 多線程和並發編程的核心概念包括線程的創建與管理、同步與互斥、條件變量、線程池、異步編程、常見錯誤與調試技巧以及性能優化與最佳實踐。 1)創建線程使用std::thread類,示例展示瞭如何創建並等待線程完成。 2)同步與互斥使用std::mutex和std::lock_guard保護共享資源,避免數據競爭。 3)條件變量通過std::condition_variable實現線程間的通信和同步。 4)線程池示例展示瞭如何使用ThreadPool類並行處理任務,提高效率。 5)異步編程使用std::as

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

SublimeText3 英文版

SublimeText3 英文版

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

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具