亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

c++刪除重復字符的方法是什么

c++
小億
162
2023-11-07 20:25:04
欄目: 編程語言

在C++中刪除重復字符的一種方法是使用哈希表。可以使用一個數組或者一個標準庫中的unordered_set來實現哈希表。具體步驟如下:

  1. 遍歷字符串的每個字符。
  2. 檢查當前字符是否已經在哈希表中存在。
  3. 如果當前字符不存在于哈希表中,將其加入哈希表,并將其添加到新的字符串中。
  4. 如果當前字符已經存在于哈希表中,說明是重復字符,跳過該字符。
  5. 最終得到的新字符串就是刪除重復字符后的結果。

以下是一個使用unordered_set的示例代碼:

#include <iostream>
#include <unordered_set>
#include <string>

std::string removeDuplicates(const std::string& str) {
    std::string result;
    std::unordered_set<char> uniqueChars;

    for (char c : str) {
        if (uniqueChars.find(c) == uniqueChars.end()) {
            uniqueChars.insert(c);
            result += c;
        }
    }

    return result;
}

int main() {
    std::string input = "abracadabra";
    std::string result = removeDuplicates(input);
    std::cout << result << std::endl;  // 輸出 "abrcd"
    return 0;
}

注意:這種方法會保留第一次出現的字符,刪除其余重復的字符。如果要保留最后一次出現的字符,可以將哈希表的類型改為std::unordered_map<char, int>,將字符映射到它們在字符串中的索引位置。在遍歷字符串時,更新哈希表中字符的索引值。在最后,遍歷哈希表,將索引值最大的字符添加到結果字符串中。

0
东方市| 杂多县| 德兴市| 天津市| 利津县| 吴桥县| 江达县| 宁陵县| 龙胜| 赤水市| 青冈县| 鲁甸县| 敖汉旗| 始兴县| 武胜县| 高陵县| 军事| 通道| 普洱| 甘南县| 晋江市| 岳阳县| 深圳市| 孝昌县| 长汀县| 安义县| 调兵山市| 化德县| 汉中市| 凌海市| 英吉沙县| 琼结县| 衡南县| 龙泉市| 隆林| 上犹县| 大城县| 黄平县| 正阳县| 辽阳县| 竹溪县|