您当前位于:
HTML5面试题 ——> WEB前端面试真题 - 如何查找字符串中出现最多的字符
WEB前端面试真题 - 如何查找字符串中出现最多的字符
2015/07/14 21:23:44
|
作者:HTML5学堂(码匠)
|
分类:HTML5面试题
|
关键词:前端,面试题,查找字符串,最多字符
查找字符串中出现最多的字符
HTML5学堂:正则、数组、字符串,是JavaScript语言中让人头痛的一些知识,今天这篇文章我们使用数组字符串的方法,来实现从一个字符串中,查找出现最多的字符。
查找字符串中出现最多的字符
将一个字符串中,出现次数最多的数字提取出来,最后输出出现最多的字符是什么,出现的次数是多少。
题目剖析
字符串方法的解题思路:从最初开始进行字符的截取,获取到第一个字符之后,根据这个字符进行字符串的拆分,此时,拆分后的数组中就没有这个字符了。再将数组组合成字符串之后,原来的长度与当前字符串的长度做差值,就能够获取到当前字符出现了几次。之后运用新的字符串,循环进行操作。需要注意的地方就是,对于出现次数相同的字符,也需要考虑。
相关知识点的使用:字符串、数组方面,需要使用到charAt、split、join、push方法;正则方面,需要使用到子项。
欢迎沟通交流~HTML5学堂
字符串方法 - 查找字符串中出现最多的字符
-
/*
-
* HTML5 数组字符串正则表达式
-
* HTML5学堂 http://www.h5course.com
-
* 独行冰海 梦幻雪冰
-
*/
-
function getMost(str){
-
var maxNum = 0;
-
var maxChar = []; //存放出现字数最多的字符数组,因为出现最多的字符可能有多个
-
while(str){
-
var char = str.charAt(0);
-
var arr = str.split(char);
-
n = str.length - arr.join('').length;
-
str = arr.join('');
-
if(n > maxNum){
-
maxNum = n;
-
maxChar = [char]; // 放置数组元素
-
}else if( n === maxNum){
-
maxChar.push(char); //出现次数相同的字符 存入数组里
-
}
-
}
-
return {'maxNum':maxNum, 'maxChar':maxChar}
-
}
-
var res = getMost('dsfshkgfareasfd');
-
console.log('出现次数最多的字符:'+ res.maxChar + ',出现次数:' + res.maxNum);
正则方法 - 查找字符串中出现最多的字符
-
/*
-
* HTML5 数组字符串正则表达式
-
* HTML5学堂 http://www.h5course.com
-
* 独行冰海 梦幻雪冰
-
*/
-
var str = 'dsfshkgfareasfd';
-
var arr = str.split('');
-
arr = arr.sort();
-
str = arr.join('');
-
-
// 先进行排序处理,然后重新组装成字符串
-
var reg = /(\w)\1+/g;
-
var num = 0;
-
var value = null;
-
str.replace(reg, function($0, $1){
-
if (num < $0.length) {
-
num = $0.length;
-
value = $1;
-
};
-
});
-
console.log(value+'出现次数'+num);
欢迎沟通交流~HTML5学堂
阅读:608