查找字符串中出现次数最多的单词
var str = "aabkxhsssseee";
function longest(str) {
let m = {};
for (let i = 0; i < str.length; i++) {
let c = str.charAt(i);
m[c] = m[c] ? m[c] + 1 : 1
}
let max = 'a'
for (let i in m) {
max = m[i] > m[max] ? i : max
}
return max
}
console.log(longest(str))
刚开始拿到题目,我习惯性的想到了 filter,find 这些 ,用简单的性能测试函数看了一下,大概是命令式的3倍性能开销,由于JavaScript数组性能相对较低,也借鉴了使用对象标记的方式,然后用 基础的 for in 运算符 找到结果。
function testFn(fn, param) {
var start = new Date().getTime();
for (let i = 0; i < 100000; i++) {
fn(param);
}
var end = new Date().getTime();
console.log(fn.name + "耗时:" + (end - start) + "毫秒"); //IE不支持fn.name
}
后来是觉得这个函数测的不准确,搜了一下果然是有更准确的方法。。。同时又仔细想了一下,觉得这个阶段暂时没有时间和必要去搞得太深入。 网上搜到算法的,先自己实现一下,然后和人家的对比对比,心里有点B数就行😒。。 。。。
点击查看更多内容
1人点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦