网上有这样一道题目:

一个字符串String=“adadfdfseffserfefsefseetsdg”,找出里面出现次数最多的字母和出现的次数。

经典的解答思路为:取出字符串的第一个字符(首字母),利用的字符串的 replace 方法将符合正则表达式(第一个字符)替代为空,此字母出现的次数为原始的字符串长度减去替代后的字符串长度。循环迭代找出长度最长的字母。

<script type="text/javascript">  

var str ="adadfdfseffserfefsefseeffffftsdg"; //命名一个变量放置给出的字符串
var maxLength = 0; //命名一个变量放置字母出现的最高次数并初始化为0
var result = ''; //命名一个变量放置结果输入  

while( str != '' ){ //循环迭代开始,并判断字符串是否为空
	oldStr = str; //将原始的字符串变量赋值给新变量
	getStr = str.substr(0,1); //用字符串的substr的方法得到第一个字符(首字母)
	eval("str = str.replace(/"+getStr+"/g,'')"); //详细如补充  

	if( oldStr.length-str.length > maxLength ) { //判断原始的字符串的长度减去替代后字符串长度是否大于之前出现的最大的字符串长度
		maxLength = oldStr.length-str.length; //两字符串长度相减得到最大的字符串长度
		result = getStr + "=" + maxLength //返回最大的字符串结果(字母、出现次数)
	}
}  

alert(result) //弹出结果  

</script>

补充:

eval("str = str.replace(/"+getStr+"/g,'')");

可能很多人想这样写 str = str.replace(/getStr/g,”),可结果却是会出错的。为什么呢,在这句中正则表达式匹配的是 getStr 字符串,而不是 getStr 指向的首字母。通过 eval 方法可以避免(首先 getStr 得到指向的首字母,用字符串连接 “str = str.replace(/”+getStr+”/g,”)”,最后在 eval 中执行这段代码,即:先解释Javascript 代码,然后再执行它)。

由于 eval 性能不好,容易出错,而且可读性不好。建议将 eval(“str = str.replace(/”+getStr+”/g,”)”) 改为:

str = str.replace(new RegExp(getStr,"g"),"")


共有3 条评论

  1. 1. 头像 快乐笛子

    var str =”adadfdfseffserfefsefseeffffftsdg”;
    var arr = str.split(“”);
    var obj = {};
    var objArr = [];
    for(var i=0,j; j=arr[i]; i++){
    if(!obj[j])obj[j]=0;
    objArr[++obj[j]]=j;
    }
    alert(objArr[objArr.length-1]+”==”+(objArr.length-1));

    希望能交换链接~,谢谢

  2. 2. JS计算字符串中出现次数最多字符 | Wang Jun's Blog

    [...] http://www.planabc.net/2007/09/05/which_letter_most_times/ [...]

  3. 3. 头像 sking7

    str = str.replace(/getStr/g,”),这样写?怎么会呢。。

发表评论

(必填)

(必填,会为您保密)

评论仅支持“a、abbr、strong、em、blockquote、code”几个简单的标签