劍指 Offer 50 第乙個只出現一次的字元

2021-10-14 01:45:51 字數 416 閱讀 7910

將第一次出現的字元存入雜湊表,並將值設為1,出現第二次時將雜湊表的值改為0,然後遍歷雜湊表,得到第乙個為1的字元。

class solution 

else hs.put(c,1);

}for(map.entryc: hs.entryset())

return ' ';}}

為什麼不用hashmap而用linkedhashmap呢?因為後者是有序的,可以遍歷搜尋雜湊表中的鍵值對,而前者是無序的,則不能遍歷雜湊表,前者只能遍歷字串,而雜湊表是去重的,因此雜湊表的長度比字串短,所以遍歷雜湊錶比遍歷字串耗時更短。

劍指Offer50 第乙個只出現一次字元

class solution for auto c s for auto c s return 自己寫的 劣勢在於使用集合而不是對映,因此無法存對應字元出現的次數,因此當insert乙個重複字元時,它可能是所求的目標字元,也可能是後面的,例如google,insert第二個o時,當前所求的目標字元 ...

劍指Offer 50 第乙個只出現一次的字元

在字串中找到第乙個只出現一次的字元。例 輸入 abaccdeff 則輸出 b 遍歷字串,每個字母第一次出現時將字母作為key,index作為val存入字典,當在字典中有key時,則將val改寫為 1,表示出現2次以上。遍歷字串結束後,遍歷字典,輸出位置最小的字元。時間複雜度 o n 空間複雜度 o ...

劍指offer 50 第乙個只出現一次的字元

劍指offer 50.第乙個只出現一次的字元 edited by ryunin date 2019 05 06 include include needed using namespace std using namespace gnu cxx needed class solution else ...