方法1: 先按空格把字符串轉換成數組,然后用for循環獲取每一個數組元素的長度,再比較大小:
function findLongestWord(str) {
var length = 0;
var strArray = str.split(' ');
for(var i = 0;i < strArray.length;i++)
{
length = strArray[i].length > length ? strArray[i].length : length;
}
return length;
}
findLongestWord("Hello world My heart will go on the day after tomorrow");
方法2:把字符串轉化成數組后,用sort()函數給數組排序:
function findLongestWord1(str) {
var strArray = str.split(' ');
strArray.sort(function (a,b) {
return b.length - a.length;
});
return strArray[0].length;
}
方法3:轉化成數組后,用map()函數生成一個保存每個單詞長度的新數組,然后用reduce()函數取到最大值:
function findLongestWord2(str) {
var strArray = str.split(' ');
var lengthArray = strArray.map(function(val){
return val.length
});
return lengthArray.reduce(function (p,c) {
return Math.max(p, c);
});
}