搜尋
首頁後端開發C++計算在僅一個位置上不同的字串對的數量

計算在僅一個位置上不同的字串對的數量

簡介

字串由字母數字字元組成,每個字元都與一個確定的位置相關聯。字元的位置範圍從 0 到字串長度。在一個位置完全不同的字元稱為相鄰字元。

在本文中,我們將開發一種程式碼,該程式碼將一個字串陣列作為輸入,這些字串在一個位置上完全不同。讓我們看下面的例子來更好地理解這個主題 -

範例

範例 1 - str - {“abc”、“cba”、“dbc”、“acc”}

輸出 - 2

例如,在下面的範例中,可以產生兩對{“abc”,“dbc”}和{“abc”,acc”}。這些字串分別僅在一個字元位置上有所不同。

在本文中,我們將開發一個程式碼,利用映射來儲存相似的字串以及取得字串對總數的模式。 C 映射利用鍵值對以便以恆定的時間複雜度儲存和檢索資料。

文法

substr()

substr() 方法用於存取較大字串中從 start 到 end-1 位置的子字串。所有要存取的索引應該是連續且有序的。

參數 -

st - 起始位置

end - 終止子字串存取的結束位置

演算法

  • 接受字串向量,字串

  • #最初維護一個計數器來儲存滿足條件的總對的計數。

  • 維護兩個映射來儲存相同的字串以及滿足保留通配符的模式的字串。讓我們假設這個映射是 m1。

  • 維護另一個映射來儲存相似的字串。讓我們假設這個映射是 m2。

  • 對輸入數組執行迭代。

  • 每次觀察到類似類型的字串,m2 映射中其對應的計數就會遞增

  • #子字串是透過使用通配符替換字串的各個字元來建立的

  • 每次觀察到類似類型的模式,m1 圖中對應的計數就會增加

  • 計算分別在 m1 和 m2 中觀察到的字串對的總和。

  • 使用這些總和值來增加計數。

範例

以下 C 程式碼片段用於將字串陣列作為輸入,並計算僅在一個位置不同的對的總數 -

//including the required libraries
#include <bits/stdc++.h>
using namespace std;
 
// Function to return the count of same pairs
int countPairs(map<string, int> &d) {
   //maintaining the count 
   int sum = 0;
   for (auto i : d)
       sum += (i.second * (i.second - 1)) / 2;
 
   return sum;
}
//called method to calculate strings differing by one character
void chardiff(vector<string> &array, int len , int n ) {
   //count to store pairs
    int cnt = 0;
   //storing strings with wildcard characters
    map<string, int> pattern;
   //storing equivalent strings
    map<string, int> similar;
   //iterating over the array
   for (auto str : array) {
      //if two strings are same , increment the count
       similar[str]+= 1;
 
      // Iterating on a single string
       for (int i = 0; i < len ; i++) {
      // Adding special symbol to the string
       string first = str.substr(0, i);
       string second = str.substr(i + 1);
       string temp =  first + "//" + second ;
 
      //incrementing if similar pattern 
        pattern[temp]+=1;
      }
   }
 
   // Return counted pairs - equal pairs
   int chnged = countPairs(pattern);
   int sim = countPairs(similar);
   cnt =  chnged - sim * len;
   cout << "The count of pairs satisfying the condition are : " << cnt; 
}
 
//calling the main method
int main() {
   int n = 4, len = 3;
   //getting a vector of strings to process
   vector<string> strings = {"get","set","bet","bat"};
   cout << "Vector of strings : " << "\n" ;
   for(auto s : strings){
       cout << s <<"\n";
   }
   //one character different
   chardiff(strings, len , n );
 
   return 0;
}

輸出

Vector of strings − 
get
set
bet
bat
The count of pairs satisfying the condition are − 4

結論

Maps 以 O(1) 時間複雜度模擬記錄插入和更新的過程。 C 中的 substring 方法可用於以指定索引之間的順序存取字串的字元。 n 和 n-1 的積除以 2 即可得到任意數量的對的總和。

以上是計算在僅一個位置上不同的字串對的數量的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:tutorialspoint。如有侵權,請聯絡admin@php.cn刪除
C面試問題和答案:ACE您的下一次技術評估C面試問題和答案:ACE您的下一次技術評估Apr 28, 2025 am 12:10 AM

C 面試中,智能指針是關鍵工具,幫助管理內存並減少內存洩漏。 1)std::unique_ptr提供獨占所有權,確保資源自動釋放。 2)std::shared_ptr用於共享所有權,適用於多引用場景。 3)std::weak_ptr可避免循環引用,確保安全資源管理。

C的未來:改編和創新C的未來:改編和創新Apr 27, 2025 am 12:25 AM

C 的未來將專注於並行計算、安全性、模塊化和AI/機器學習領域:1)並行計算將通過協程等特性得到增強;2)安全性將通過更嚴格的類型檢查和內存管理機制提升;3)模塊化將簡化代碼組織和編譯;4)AI和機器學習將促使C 適應新需求,如數值計算和GPU編程支持。

C的壽命:檢查其當前狀態C的壽命:檢查其當前狀態Apr 26, 2025 am 12:02 AM

C 在現代編程中依然重要,因其高效、靈活和強大的特性。 1)C 支持面向對象編程,適用於系統編程、遊戲開發和嵌入式系統。 2)多態性是C 的亮點,允許通過基類指針或引用調用派生類方法,增強代碼的靈活性和可擴展性。

C#vs. C性能:基準測試和注意事項C#vs. C性能:基準測試和注意事項Apr 25, 2025 am 12:25 AM

C#和C 在性能上的差異主要體現在執行速度和資源管理上:1)C 在數值計算和字符串操作上通常表現更好,因為它更接近硬件,沒有垃圾回收等額外開銷;2)C#在多線程編程上更為簡潔,但性能略遜於C ;3)選擇哪種語言應根據項目需求和團隊技術棧決定。

C:死亡還是簡單地發展?C:死亡還是簡單地發展?Apr 24, 2025 am 12:13 AM

1)c relevantduetoItsAverity and效率和效果臨界。 2)theLanguageIsconTinuellyUped,withc 20introducingFeaturesFeaturesLikeTuresLikeSlikeModeLeslikeMeSandIntIneStoImproutiMimproutimprouteverusabilityandperformance.3)

C在現代世界中:應用和行業C在現代世界中:應用和行業Apr 23, 2025 am 12:10 AM

C 在現代世界中的應用廣泛且重要。 1)在遊戲開發中,C 因其高性能和多態性被廣泛使用,如UnrealEngine和Unity。 2)在金融交易系統中,C 的低延遲和高吞吐量使其成為首選,適用於高頻交易和實時數據分析。

C XML庫:比較和對比選項C XML庫:比較和對比選項Apr 22, 2025 am 12:05 AM

C 中有四種常用的XML庫:TinyXML-2、PugiXML、Xerces-C 和RapidXML。 1.TinyXML-2適合資源有限的環境,輕量但功能有限。 2.PugiXML快速且支持XPath查詢,適用於復雜XML結構。 3.Xerces-C 功能強大,支持DOM和SAX解析,適用於復雜處理。 4.RapidXML專注於性能,解析速度極快,但不支持XPath查詢。

C和XML:探索關係和支持C和XML:探索關係和支持Apr 21, 2025 am 12:02 AM

C 通過第三方庫(如TinyXML、Pugixml、Xerces-C )與XML交互。 1)使用庫解析XML文件,將其轉換為C 可處理的數據結構。 2)生成XML時,將C 數據結構轉換為XML格式。 3)在實際應用中,XML常用於配置文件和數據交換,提升開發效率。

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脫衣器

Video Face Swap

Video Face Swap

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

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

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

記事本++7.3.1

記事本++7.3.1

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

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器