【发布时间】:2011-06-29 13:16:31
【问题描述】:
有没有捷径可以在字符串数组中找到最长的字符串?
类似arr.Max(x => x.Length);?
【问题讨论】:
标签: javascript
有没有捷径可以在字符串数组中找到最长的字符串?
类似arr.Max(x => x.Length);?
【问题讨论】:
标签: javascript
自Javascript 1.8/ECMAScript 5 起可用,大多数older browsers 可用:
var longest = arr.reduce(
function (a, b) {
return a.length > b.length ? a : b;
}
);
否则,一个安全的选择:
var longest = arr.sort(
function (a, b) {
return b.length - a.length;
}
)[0];
【讨论】:
reduce 与返回数组的回调函数一起使用。
一个老问题的新答案:在 ES6 中你可以做得更短:
Math.max(...(x.map(el => el.length)));
【讨论】:
O(n^2),而大多数其他选项只会遍历集合一次 O(n)。自定义比较器可能使用 sort 甚至可能是 O(log(n))
O(n) + O(n) = O(n),而不是O(n^2)。
我会做这样的事情
var arr = [
'first item',
'second item is longer than the third one',
'third longish item'
];
var lgth = 0;
var longest;
for (var i = 0; i < arr.length; i++) {
if (arr[i].length > lgth) {
var lgth = arr[i].length;
longest = arr[i];
}
}
console.log(longest);
【讨论】:
var lgth?在不重新声明lgth 的情况下这样做会给我正确的答案。但是,我在自己的版本中将所有var 更改为let。
也许不是最快的,但肯定非常易读:
function findLongestWord(array) {
var longestWord = "";
array.forEach(function(word) {
if(word.length > longestWord.length) {
longestWord = word;
}
});
return longestWord;
}
var word = findLongestWord(["The","quick","brown", "fox", "jumped", "over", "the", "lazy", "dog"]);
console.log(word); // result is "jumped"
【讨论】:
var arr = [ 'fdgdfgdfg', 'gdfgf', 'gdfgdfhawsdgd', 'gdf', 'gdfhdfhjurvweadsd' ];
arr.sort(function (a, b) { return b.length - a.length })[0];
【讨论】:
在 ES6 中,这可以通过 reduce() 复杂度的 reduce() 调用来完成,而不是使用 sort() 的解决方案,即 O(nlogn):
const getLongestText = (arr) => arr.reduce(
(savedText, text) => (text.length > savedText.length ? text : savedText),
'',
);
console.log(getLongestText(['word', 'even-longer-word', 'long-word']))
【讨论】:
arr.reduce(function(savedText, text) { return text.length > savedText.length ? text : savedText; }, '');
我提供了一种函数式+递归的方法。查看 cmets 了解其工作原理:
const input1 = ['a', 'aa', 'aaa']
const input2 = ['asdf', 'qwer', 'zxcv']
const input3 = ['asdfasdf fdasdf a sd f', ' asdfsdf', 'asdfasdfds', 'asdfsdf', 'asdfsdaf']
const input4 = ['ddd', 'dddddddd', 'dddd', 'ddddd', 'ddd', 'dd', 'd', 'd', 'dddddddddddd']
// Outputs which words has the greater length
// greatestWord :: String -> String -> String
const greatestWord = x => y =>
x.length > y.length ? x : y
// Recursively outputs the first longest word in a series
// longestRec :: String -> [String] -> String
const longestRec = longestWord => ([ nextWord, ...words ]) =>
// ^^^^^^^^^^^^
// Destructuring lets us get the next word, and remaining ones!
nextWord // <-- If next word is undefined, then it won't recurse.
? longestRec (greatestWord (nextWord) (longestWord)) (words)
: longestWord
// Outputs the first longest word in a series
// longest :: [String] -> String
const longest = longestRec ('')
const output1 = longest (input1)
const output2 = longest (input2)
const output3 = longest (input3)
const output4 = longest (input4)
console.log ('output1: ', output1)
console.log ('output2: ', output2)
console.log ('output3: ', output3)
console.log ('output4: ', output4)
【讨论】:
我受到 Jason 的功能的启发,对其进行了一些改进,结果发现速度相当快:
function timo_longest(a) {
var c = 0, d = 0, l = 0, i = a.length;
if (i) while (i--) {
d = a[i].length;
if (d > c) {
l = i; c = d;
}
}
return a[l];
}
arr=["First", "Second", "Third"];
var longest = timo_longest(arr);
【讨论】:
我看到了最短的解决方案
function findLong(s){
return Math.max.apply(null, s.split(' ').map(w => w.length));
}
【讨论】:
如果您的字符串已经拆分为数组,则不需要拆分部分。
function findLongestWord(str) {
str = str.split(' ');
var longest = 0;
for(var i = 0; i < str.length; i++) {
if(str[i].length >= longest) {
longest = str[i].length;
}
}
return longest;
}
findLongestWord("The quick brown fox jumped over the lazy dog");
【讨论】:
如果您期望超过一个最大值,这将起作用:
_.maxBy(Object.entries(_.groupBy(x, y => y.length)), y => parseInt(y[0]))[1]
它使用 lodash 并返回一个数组。
【讨论】:
ES6 支持重复字符串
var allLongestStrings = arrayOfStrings => {
let maxLng = Math.max(...arrayOfStrings.map( elem => elem.length))
return arrayOfStrings.filter(elem => elem.length === maxLng)
}
let arrayOfStrings = ["aba", "aa", "ad", "vcd","aba"]
console.log(allLongestStrings(arrayOfStrings))
【讨论】:
我会这样做:
function findLongestWord(str) {
var array = str.split(" ");
var maxLength=array[0].length;
for(var i=0; i < array.length; i++ ) {
if(array[i].length > maxLength) maxLength = array[i].length
}
return maxLength;
}
findLongestWord("What if we try a super-long word such as otorhinolaryngology");
【讨论】:
function max( input ) {
return input.reduce((a, b) => a.length <= b.length ? b : a)
}
【讨论】:
如果你想知道最长项目的索引:
var longest = arr.reduce(
(a, b, i) => arr[a].length < b.length ? i : a,
0
);
(对于那些喜欢这些东西的人来说,这可能是一个单行字……但为了便于阅读,它在这里被分开了)
【讨论】:
Modern browsers support a for...of loop.在Chrome、Safari、Edge、Firefox中解决这个问题最快最短的方法也是最清楚的:
let largest = '';
for (let item of arr) {
if (item.length > largest.length) largest = item
}
In IE, you can use Array.forEach;这仍然比排序或减少数组更快更清晰。
var largest = '';
arr.forEach(function(item) {
if (item.length > largest.length) largest = item
});
【讨论】: