前端算法題解leetcode49-字母異位詞分組
題目
給你一個字符串數(shù)組,請你將 字母異位詞 組合在一起??梢园慈我忭樞蚍祷亟Y果列表。
字母異位詞 是由重新排列源單詞的字母得到的一個新單詞,所有源單詞中的字母通常恰好只用一次。
示例 1:
輸入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
輸出: [["bat"],["nat","tan"],["ate","eat","tea"]
示例 2:
輸入: strs = [""]
輸出: [[""]]
示例 3:
輸入: strs = ["a"]
輸出: [["a"]]
提示:
1 <= strs.length <= 1040 <= strs[i].length <= 100strs[i]僅包含小寫字母
解題思路
首先我們來搞懂本題的題意,所謂 字母異位詞 就是一個單詞通過改變單詞內(nèi)字母的順序可以得到另一個單詞,那么這兩個單詞就是字母異位詞,例如 abc 和 cba 和 acb。
接下來要解決的就是如何判斷單詞互為字母異位詞?
因為字母異位詞單詞內(nèi)字母及出現(xiàn)次數(shù)相同,所以我可以把單詞內(nèi)的字母排序,這樣互為字母異位詞的單詞排序后的結果就是相同的,把排序后結果相同的單詞的下標記錄在一組,這樣互為字母異位詞的單詞就被收集到了一組。
最后遍歷得到的信息,將同組的下標對應的單詞放到一個數(shù)組,再將該數(shù)組插入到結果數(shù)組,最后返回結果數(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-字母異位詞分組,更多關于前端算法字母異位詞分組的資料請關注腳本之家其它相關文章!
相關文章
JS封裝轉換前后端接口數(shù)據(jù)格式工具函數(shù)下劃線<=>大寫
這篇文章主要為大家介紹了JS優(yōu)雅封裝轉換前后端接口數(shù)據(jù)格式工具函數(shù)下劃線<=>大寫實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03
自定義range?sliders滑塊實現(xiàn)元素拖動方法
這篇文章主要為大家介紹了自定義range?sliders滑塊實現(xiàn)元素拖動方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08

