使用 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' ] ]

更新日期:27-Jan-2021

950 次浏览

开始你的 职业生涯

完成课程后获得认证

开始
广告
© . All rights reserved.