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

前端算法題解leetcode49-字母異位詞分組

 更新時間:2022年09月23日 10:08:54   作者:前端_奔跑的蝸牛  
這篇文章主要為大家介紹了前端算法leetcode49-字母異位詞分組解題示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

題目

題目地址

給你一個字符串?dāng)?shù)組,請你將 字母異位詞 組合在一起??梢园慈我忭樞蚍祷亟Y(jié)果列表。

字母異位詞 是由重新排列源單詞的字母得到的一個新單詞,所有源單詞中的字母通常恰好只用一次。

示例 1:

輸入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]

輸出: [["bat"],["nat","tan"],["ate","eat","tea"]

示例 2:

輸入: strs = [""]

輸出: [[""]]

示例 3:

輸入: strs = ["a"]

輸出: [["a"]]

提示:

  • 1 <= strs.length <= 104
  • 0 <= strs[i].length <= 100
  • strs[i] 僅包含小寫字母

解題思路

首先我們來搞懂本題的題意,所謂 字母異位詞 就是一個單詞通過改變單詞內(nèi)字母的順序可以得到另一個單詞,那么這兩個單詞就是字母異位詞,例如 abccbaacb。

接下來要解決的就是如何判斷單詞互為字母異位詞?

因為字母異位詞單詞內(nèi)字母及出現(xiàn)次數(shù)相同,所以我可以把單詞內(nèi)的字母排序,這樣互為字母異位詞的單詞排序后的結(jié)果就是相同的,把排序后結(jié)果相同的單詞的下標(biāo)記錄在一組,這樣互為字母異位詞的單詞就被收集到了一組。

最后遍歷得到的信息,將同組的下標(biāo)對應(yīng)的單詞放到一個數(shù)組,再將該數(shù)組插入到結(jié)果數(shù)組,最后返回結(jié)果數(shù)組即可。

代碼實現(xiàn)

var groupAnagrams = function(strs) {
    let _strs = [...strs]
    const res = []
    const map = new Map()
    for(let i = 0;i<_strs.length;i++){
        let str = _strs[i]
        str = str.split('').sort((a,b) => a.localeCompare(b)).join('')
        if(map.has(str)){
            map.get(str).push(i)
            continue
        }
        map.set(str,[i])
    }
    map.forEach(item => {
        const arr = []
        for(let i = 0;i<item.length;i++){
            arr.push(strs[item[i]])
        }
        res.push(arr)
    })
    return res
}

至此我們就完成了 leetcode-49-字母異位詞分組,更多關(guān)于前端算法字母異位詞分組的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論