欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go Java算法之單詞規(guī)律示例詳解

 更新時間:2022年08月20日 16:23:45   作者:黃丫丫  
這篇文章主要為大家介紹了Go Java算法之單詞規(guī)律示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

單詞規(guī)律

給定一種規(guī)律 pattern 和一個字符串 s ,判斷 s 是否遵循相同的規(guī)律。

這里的 遵循 指完全匹配,例如, pattern 里的每個字母和字符串 s 中的每個非空單詞之間存在著雙向連接的對應(yīng)規(guī)律。

  • 示例1:

輸入: pattern = "abba", s = "dog cat cat dog"

輸出: true

  • 示例 2:

輸入:pattern = "abba", s = "dog cat cat fish"

輸出: false

  • 示例 3:

輸入: pattern = "aaaa", s = "dog cat cat dog"

輸出: false  

提示:

1 <= pattern.length <= 300

pattern 只包含小寫英文字母

1 <= s.length <= 3000

s 只包含小寫英文字母和 ' '

s 不包含 任何前導(dǎo)或尾隨對空格

s 中每個單詞都被 單個空格 分隔

方法一:哈希表(Java)

在本題中,我們需要判斷字符與字符串之間是否恰好一一對應(yīng)。即任意一個字符都對應(yīng)著唯一的字符串,任意一個字符串也只被唯一的一個字符對應(yīng)。在集合論中,這種關(guān)系被稱為「雙射」。

想要解決本題,我們可以利用哈希表記錄每一個字符對應(yīng)的字符串,以及每一個字符串對應(yīng)的字符。然后我們枚舉每一對字符與字符串的配對過程,不斷更新哈希表,如果發(fā)生了沖突,則說明給定的輸入不滿足雙射關(guān)系。

題目本質(zhì)上是讓我們判斷str中的字符是否與pattern中的字符一一對應(yīng)

也就是說,pattern中相同的字符在str中也應(yīng)該相同,不同的字符在str中也應(yīng)該不同

我們可以通過一個字典記錄pattern中每個字符第一次出現(xiàn)的位置,即dict[x]=pattern.index(x)。然后我們遍歷對pattern中的每個字母,

記i為當(dāng)前遍歷的索引

則dict[pattern[i]]為pattern中字符pattern[i]的上個索引

判斷str中兩個索引所對應(yīng)的字母是否相同,若不同則返回False

class Solution {
    public boolean wordPattern(String pattern, String str) {
        Map<String, Character> str2ch = new HashMap<String, Character>();
        Map<Character, String> ch2str = new HashMap<Character, String>();
        int m = str.length();
        int i = 0;
        for (int p = 0; p < pattern.length(); ++p) {
            char ch = pattern.charAt(p);
            if (i >= m) {
                return false;
            }
            int j = i;
            while (j < m && str.charAt(j) != ' ') {
                j++;
            }
            String tmp = str.substring(i, j);
            if (str2ch.containsKey(tmp) && str2ch.get(tmp) != ch) {
                return false;
            }
            if (ch2str.containsKey(ch) && !tmp.equals(ch2str.get(ch))) {
                return false;
            }
            str2ch.put(tmp, ch);
            ch2str.put(ch, tmp);
            i = j + 1;
        }
        return i >= m;
    }
}

時間復(fù)雜度:O(n+m)

空間復(fù)雜度:O(n+m)

方法一:哈希表(GO)

具體的方法思路內(nèi)容已經(jīng)在上文中表述,詳情請看上文內(nèi)容

具體方法:

pattern = "abba", 轉(zhuǎn)成0110

str = "dog cat cat dog",轉(zhuǎn)成0110

func wordPattern(pattern string, str string) bool {
    p := strings.Split(pattern,"")
    s := strings.Split(str," ")
    if len(p) != len(s) {
        return false
    }
    pNum,sNum := 0,0
    pString,sString := "",""
    pMap := map[string]int{}
    sMap := map[string]int{}
    for _,v := range p {
        if _,ok := pMap[v];ok{
            pString += strconv.Itoa(pMap[v])
        }else{
            pString += strconv.Itoa(pNum)
            pMap[v] = pNum
            pNum++
        }
    }
    for _,v := range s {
        if _,ok := sMap[v];ok{
            sString += strconv.Itoa(sMap[v])
        }else{
            sString += strconv.Itoa(sNum)
            sMap[v] = sNum
            sNum++
        }
    }
    if pString == sString {
        return true
    }
    return false
}

時間復(fù)雜度:O(n+m)

空間復(fù)雜度:O(n+m)

以上就是Go Java算法之單詞規(guī)律示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Go Java算法單詞規(guī)律的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Golang使用Channel組建高并發(fā)HTTP服務(wù)器

    Golang使用Channel組建高并發(fā)HTTP服務(wù)器

    Golang 作為一門高效的語言,在網(wǎng)絡(luò)編程方面表現(xiàn)也非常出色,這篇文章主要介紹了如何使用 Golang 和 Channel 組建高并發(fā) HTTP 服務(wù)器,感興趣的可以了解一下
    2023-06-06
  • golang的Pseudo-versions使用問題解析

    golang的Pseudo-versions使用問題解析

    這篇文章主要為大家介紹有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪了golang的Pseudo-versions使用問題解析,
    2023-07-07
  • golang切片擴(kuò)容規(guī)則實現(xiàn)

    golang切片擴(kuò)容規(guī)則實現(xiàn)

    這篇文章主要介紹了golang切片擴(kuò)容規(guī)則實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • golang定時器Timer的用法和實現(xiàn)原理解析

    golang定時器Timer的用法和實現(xiàn)原理解析

    這篇文章主要介紹了golang定時器Ticker,本文主要來看一下Timer的用法和實現(xiàn)原理,需要的朋友可以參考以下內(nèi)容
    2023-04-04
  • GoLang中panic與recover函數(shù)以及defer語句超詳細(xì)講解

    GoLang中panic與recover函數(shù)以及defer語句超詳細(xì)講解

    這篇文章主要介紹了GoLang的panic、recover函數(shù),以及defer語句,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-01-01
  • Golang極簡入門教程(二):方法和接口

    Golang極簡入門教程(二):方法和接口

    這篇文章主要介紹了Golang極簡入門教程(二):方法和接口,本文同時講解了錯誤、匿名域等內(nèi)容,需要的朋友可以參考下
    2014-10-10
  • Go 字符串比較的實現(xiàn)示例

    Go 字符串比較的實現(xiàn)示例

    本文主要介紹了Go 字符串比較的實現(xiàn)示例,主要包括三種比較方式,具有一定的參考價值,感興趣的可以了解一下
    2022-01-01
  • go語言中strings包的用法匯總

    go語言中strings包的用法匯總

    Golang語言 strings標(biāo)準(zhǔn)庫包主要涉及字符串的基本操作,下面我們來詳細(xì)分析下吧
    2018-10-10
  • gRPC的發(fā)布訂閱模式及REST接口和超時控制

    gRPC的發(fā)布訂閱模式及REST接口和超時控制

    這篇文章主要為大家介紹了gRPC的發(fā)布訂閱模式及REST接口和超時控制,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • 一文搞懂Go語言操作Redis的方法

    一文搞懂Go語言操作Redis的方法

    Redis是一個開源的內(nèi)存數(shù)據(jù)庫,在項目開發(fā)中redis的使用也比較頻繁,本文介紹了Go語言中g(shù)o-redis庫的基本使用。感興趣的小伙伴們可以參考借鑒一下
    2022-09-09

最新評論