Go Java算法之字符串中第一個(gè)唯一字符詳解
字符串中第一個(gè)唯一字符
給定一個(gè)字符串 s ,找到 它的第一個(gè)不重復(fù)的字符,并返回它的索引 。如果不存在,則返回 -1 。
- 示例 1:
輸入: s = "leetcode"
輸出: 0
- 示例 2:
輸入: s = "loveleetcode"
輸出: 2
- 示例 3:
輸入: s = "aabb"
輸出: -1
提示:
1 <= s.length <= 105
s 只包含小寫字母
方法一:哈希表(Java)
在第一次遍歷時(shí),我們使用哈希映射統(tǒng)計(jì)出字符串中每個(gè)字符出現(xiàn)的次數(shù)。
在第二次遍歷時(shí),我們只要遍歷到了一個(gè)只出現(xiàn)一次的字符,那么就返回它的索引,否則在遍歷結(jié)束后返回 -1。
class Solution {
public int firstUniqChar(String s) {
Map<Character, Integer> frequency = new HashMap<Character, Integer>();
for (int i = 0; i < s.length(); ++i) {
char ch = s.charAt(i);
frequency.put(ch, frequency.getOrDefault(ch, 0) + 1);
}
for (int i = 0; i < s.length(); ++i) {
if (frequency.get(s.charAt(i)) == 1) {
return i;
}
}
return -1;
}
}
n:字符串長(zhǎng)度
Σ:字符集
時(shí)間復(fù)雜度:O(n)
空間復(fù)雜度:O(∣Σ∣)
方法二:隊(duì)列(Go)
我們也可以借助隊(duì)列找到第一個(gè)不重復(fù)的字符。隊(duì)列具有「先進(jìn)先出」的性質(zhì),因此很適合用來(lái)找出第一個(gè)滿足某個(gè)條件的元素。
具體地,我們使用與方法二相同的哈希映射,并且使用一個(gè)額外的隊(duì)列,按照順序存儲(chǔ)每一個(gè)字符以及它們第一次出現(xiàn)的位置。
當(dāng)我們對(duì)字符串進(jìn)行遍歷時(shí),設(shè)當(dāng)前遍歷到的字符為 c,如果 c 不在哈希映射中,我們就將 c 與它的索引作為一個(gè)二元組放入隊(duì)尾
否則我們就需要檢查隊(duì)列中的元素是否都滿足「只出現(xiàn)一次」的要求,即我們不斷地根據(jù)哈希映射中存儲(chǔ)的值(是否為 -1)選擇彈出隊(duì)首的元素,直到隊(duì)首元素「真的」只出現(xiàn)了一次或者隊(duì)列為空。
type pair struct {
ch byte
pos int
}
func firstUniqChar(s string) int {
n := len(s)
pos := [26]int{}
for i := range pos[:] {
pos[i] = n
}
q := []pair{}
for i := range s {
ch := s[i] - 'a'
if pos[ch] == n {
pos[ch] = i
q = append(q, pair{ch, i})
} else {
pos[ch] = n + 1
for len(q) > 0 && pos[q[0].ch] == n+1 {
q = q[1:]
}
}
}
if len(q) > 0 {
return q[0].pos
}
return -1
}
n:字符串長(zhǎng)度
Σ:字符集
時(shí)間復(fù)雜度:O(n)
空間復(fù)雜度:O(∣Σ∣)
以上就是Go Java算法之字符串中第一個(gè)唯一字符詳解的詳細(xì)內(nèi)容,更多關(guān)于Go Java算法字符串唯一字符的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java中checkbox實(shí)現(xiàn)跨頁(yè)多選的方法
最近做了一個(gè)項(xiàng)目其中遇到這樣的需求,要實(shí)現(xiàn)checkbox跨頁(yè)多選功能,經(jīng)過(guò)小編整理,順利解決,今天小編給大家分享Java中checkbox實(shí)現(xiàn)跨頁(yè)多選的方法,需要的的朋友參考下2017-01-01
Java零基礎(chǔ)教程之Windows下安裝 JDK的方法圖解
這篇文章主要介紹了Java零基礎(chǔ)教程之Windows下安裝 JDK的方法圖解,本文介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
java數(shù)據(jù)結(jié)構(gòu)與算法之插入算法實(shí)現(xiàn)數(shù)值排序示例
這篇文章主要介紹了java數(shù)據(jù)結(jié)構(gòu)與算法之插入算法實(shí)現(xiàn)數(shù)值排序的方法,結(jié)合簡(jiǎn)單實(shí)例形式分析了插入算法的節(jié)點(diǎn)操作與排序相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-08-08
Java 使用JdbcTemplate 中的queryForList發(fā)生錯(cuò)誤解決辦法
這篇文章主要介紹了Java 使用JdbcTemplate 中的queryForList發(fā)生錯(cuò)誤解決辦法的相關(guān)資料,需要的朋友可以參考下2017-07-07
解決Spring國(guó)際化文案占位符失效問(wèn)題的方法
本篇文章主要介紹了解決Spring國(guó)際化文案占位符失效問(wèn)題的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04
springboot+redis自定義注解實(shí)現(xiàn)發(fā)布訂閱的實(shí)現(xiàn)代碼
在Redis中客戶端可以通過(guò)訂閱特定的頻道來(lái)接收發(fā)送至該頻道的消息,本文主要介紹了springboot+redis自定義注解實(shí)現(xiàn)發(fā)布訂閱,具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08

