【数据结构与算法】力扣 49. 字母异位词分组

题目描述

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。

字母异位词 是由重新排列源单词的所有字母得到的一个新单词。

示例 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] 仅包含小写字母

分析解答

lodash 里面自带一个方法,可以根据规则对字符串数组进行分组,而分组后的 value 刚好是我们需要的结果。

import _ from 'lodash'
/**
 * @param {string[]} strs
 * @return {string[][]}
 */
var groupAnagrams = function(strs) {
    // 先对每个字符串进行排序 作为分组规则(函数返回值为 key) 值为满足规则的数组元素组成的数组 然后进行分组
    /*
     * 例如:_.groupBy([6.1, 4.2, 6.3], Math.floor); // => { '4': [4.2], '6': [6.1, 6.3] }
     */
    const g = _.groupBy(strs, str => str.split('').sort().join(''))
    console.log(g)
    // 返回 value 组成的数组
    return Object.values(g)
};
// 测试代码
console.log(groupAnagrams(["eat", "tea", "tan", "ate", "nat", "bat"]))

思路拓展

当然不用 lodash 也可以,我们自己实现一个分组,相当于把以上 lodash 的原理实现了一遍。

/**
 * @param {string[]} strs
 * @return {string[][]}
 */
var groupAnagrams = function(strs) {
    let res = {}
    for (let str of strs) {
        let arr = str.split('').sort().join()
        if (res[arr]) {
            res[arr].push(str)
        } else {
            res[arr] = [str]
        }
    }
    return Object.values(res)
};
// 测试代码
console.log(groupAnagrams(["eat", "tea", "tan", "ate", "nat", "bat"]))

相关推荐

  1. 数据结构算法】力 49. 字母分组

    2024-05-15 16:04:03       32 阅读
  2. 49.字母分组

    2024-05-15 16:04:03       52 阅读
  3. LeetCode 49 字母分组

    2024-05-15 16:04:03       63 阅读
  4. LeetCode49字母分组

    2024-05-15 16:04:03       32 阅读
  5. leetcode_49.字母分组

    2024-05-15 16:04:03       38 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-15 16:04:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-15 16:04:03       106 阅读
  3. 在Django里面运行非项目文件

    2024-05-15 16:04:03       87 阅读
  4. Python语言-面向对象

    2024-05-15 16:04:03       96 阅读

热门阅读

  1. 大数据面试 --- 六

    2024-05-15 16:04:03       38 阅读
  2. R语言数据分析案例分析一个关于房价的数据集

    2024-05-15 16:04:03       34 阅读
  3. 平衡车电池UL2271认证是什么?

    2024-05-15 16:04:03       29 阅读
  4. Symbol类型的作用

    2024-05-15 16:04:03       28 阅读
  5. [前端] vue2的/deep/转化为vue3语法(笔记)

    2024-05-15 16:04:03       35 阅读
  6. vue3 动态加载页面

    2024-05-15 16:04:03       35 阅读
  7. error和exception的区别?

    2024-05-15 16:04:03       36 阅读
  8. ISBN查询图书api接口

    2024-05-15 16:04:03       37 阅读
  9. 解决方案:sql里的join跟left join有什么区别

    2024-05-15 16:04:03       32 阅读
  10. 探索Git:版本控制的革命(一文了解Git)

    2024-05-15 16:04:03       36 阅读
  11. 小米消金引领创新,打造重庆消费金融新生态

    2024-05-15 16:04:03       38 阅读
  12. 算法学习笔记(LCA)

    2024-05-15 16:04:03       28 阅读