LeetCode——字母异位词分组(中等)

题目

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

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

示例 1:

复制代码
输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
输出: [["bat"],["nat","tan"],["ate","eat","tea"]]

示例 2:

复制代码
输入: strs = [""]
输出: [[""]]

示例 3:

复制代码
输入: strs = ["a"]
输出: [["a"]]

题解

看了解析才做出来的,不得不说解法真的很精巧

先定义一个自定义函数,把传入的字符串先用split('')拆分成字母数组,然后用sort()排序字母,然后用join('')把字母数组还原成字符串

然后遍历题目给定的数组,分别传入函数中获得新字符串,与map比较,如果map中存在新字符串则把遍历的这个字符串加进去,如果不存在则创建map的新键值对

javascript 复制代码
/**
 * @param {string[]} strs
 * @return {string[][]}
 */
var groupAnagrams = function(strs) {
    function getkey(str)
    {
        return str.split('').sort().join('');
    }
    var map = new Map();
    for(var i of strs)
    {
        var ii = getkey(i);
        if(map.get(ii))
        {
            map.get(ii).push(i);
        }
        else{
            map.set(ii,[i]);
        }
    }
    return [...map.values()];
};

知识点

在for循环中,i of strs代表的是遍历数组中的元素,i in strs的i代表的是索引值,如果是在对象中i in strs的i代表的是属性名

...×××\]代表的是,用通俗的话来说把衣服脱了,不管是大括号(\[\])、花括号({}),统统不在话下,**全部脱掉脱掉!** ![](https://file.jishuzhan.net/article/1697340913518383105/5aa5c8b93a244930a7ac4a3ff0ce5136.png)

相关推荐
niuniudengdeng3 分钟前
六面独立转动魔方还原机器人设计与实现
数学·算法·机器人
ghie90904 分钟前
基于MATLAB的A*算法避障路径规划实现
人工智能·算法·matlab
雾岛听蓝17 分钟前
C文件操作与系统IO
linux·c语言·开发语言·经验分享·笔记·算法
全栈小520 分钟前
【前端】Vue 组件开发中的枚举值验证:从一个Type属性错误说起
前端·javascript·vue.js
Joker Zxc23 分钟前
【前端基础(Javascript部分)】4、JavaScript的分支语句
开发语言·前端·javascript
zh路西法30 分钟前
【宇树机器人强化学习】(一):PPO算法的python实现与解析
python·深度学习·算法·机器学习·机器人
随意起个昵称32 分钟前
【贪心】选择尽量多的不相交区间
数据结构·算法
章小幽42 分钟前
LeetCode-35.搜索插入位置
数据结构·算法·leetcode
꧁꫞꯭零꯭点꯭꫞꧂1 小时前
G6绘制机柜 以及机柜设备的demo
前端·javascript·vue.js
放下华子我只抽RuiKe51 小时前
机器学习全景指南-探索篇——发现数据内在结构的聚类算法
人工智能·深度学习·算法·机器学习·语言模型·数据挖掘·聚类