JavaScript 中唯一单词的最大长度乘积
问题
我们需要编写一个 JavaScript 函数,该函数以一个包含字符串的数组(仅小写字母表字符串)作为第一个,也是唯一的参数。
该函数应从数组中选择两个这样的字符串,这两个字符串没有共同的字符且有最大的长度乘积。然后,我们的函数应返回这两个字符串的长度乘积。如果数组中不存在这样的字符串,则应返回 0。
例如,如果输入函数是 -
const arr = ["karl", "n", "the", "car", "mint", "alpha"];
则输出应为 -
const output = 20;
输出说明
单词“mint”和“alpha”没有共用单词,并且它们的长度乘积为 20。
示例
相应的代码为 -
const arr = ["karl", "n", "the", "car", "mint", "alpha"];
const maxLengthProduct = (arr = []) => {
const array = [];
arr.forEach(str => {
let curr = 0;
for(let i = 0; i < str.length; i++){
curr |= 1<<(str.charCodeAt(i) - 97);
};
array.push(curr);
});
let res = 0;
for(let i = 0 ; i < array.length; i++) {
for(let j = i + 1; j < array.length ; j++) {
if((array[i] & array[j]) === 0) {
res = Math.max(res, arr[i].length * arr[j].length);
}
}
}
return res;
};
console.log(maxLengthProduct(arr));输出
控制台中的输出为 -
20
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP