使用 JavaScript 按同位异构词对其分组
同位异构词
如果两个单词或短语可以通过以不同顺序排列各个字母来构成,则称这两个单词或短语是彼此的同位异构词,例如 rat 和 tar。
我们需要编写一个 JavaScript 函数,该函数输入一个可能包含一些同位异构词字符串的字符串数组。该函数应将所有同位异构词分组到单独的子数组中,并返回由此形成的新数组。
例如 −
如果输入数组是 −
const arr = ['rat', 'jar', 'tar', 'raj','ram', 'arm', 'mar', 'art'];
则输出数组应为 −
const output = [ ['rat', 'tar', 'art'], ['jar', 'raj'], ['ram', 'arm', 'mar'] ];
示例
以下是代码 −
const arr = ['rat', 'jar', 'tar', 'raj','ram', 'arm', 'mar', 'art'];
const groupSimilarWords = (arr = []) => {
if (arr.length === 0){
return arr;
};
const map = new Map();
for(let str of arr){
let sorted = [...str];
sorted.sort();
sorted = sorted.join('');
if(map.has(sorted)){
map.get(sorted).push(str);
}else{
map.set(sorted, [str])
};
};
return [...map.values()];
};
console.log(groupSimilarWords(arr));输出
以下是控制台输出 −
[ [ 'rat', 'tar', 'art' ], [ 'jar', 'raj' ], [ 'ram', 'arm', 'mar' ] ]
广告
数据结构
网络
关系型数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP