欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Js查找字符串中出現(xiàn)次數(shù)最多的字符及個(gè)數(shù)實(shí)例解析

 更新時(shí)間:2016年09月05日 09:27:29   作者:鬼畜十三  
這篇文章主要介紹了Js查找字符串中出現(xiàn)次數(shù)最多的字符及個(gè)數(shù) ,本文分為傳統(tǒng)寫(xiě)法和正則寫(xiě)法兩種方法給大家介紹了js查找字符串出現(xiàn)次數(shù)最多的字符及個(gè)數(shù),非常不錯(cuò),感興趣的朋友參考下吧

如sssfgtdfssddfsssfssss,出現(xiàn)最多的字符是s,出現(xiàn)了12次

傳統(tǒng)寫(xiě)法

分析:

1.準(zhǔn)備一個(gè)空的json,通過(guò)循環(huán)字符串的每個(gè)字符來(lái)看,如果json里沒(méi)有這個(gè)字符,就在json里創(chuàng)建一個(gè)新的數(shù)組,并把這個(gè)字符放進(jìn)數(shù)組里,如果json里有這個(gè)字符,繼續(xù)把字符添加進(jìn)數(shù)組里,這時(shí)循環(huán)完json里有n個(gè)數(shù)組

2.找出json里長(zhǎng)度最長(zhǎng)的數(shù)組,此時(shí)長(zhǎng)度即個(gè)數(shù),而最多的字符就是這個(gè)參數(shù),用到for...in...循環(huán)和參數(shù)attr

var str="sssfgtdfssddfsssfssss";
function max(){
var json={};
var num=0;
var value=null;
for(var i=0;i<str.length;i++){
var k=str[i];
if(!json[k]){
json[k]=[];
}
json[k].push(k); //這里不需要else,否則只有存在這個(gè)字符時(shí)才添加。次數(shù)會(huì)少一次
}
for(var attr in json){
if(num<json[attr].length){
num=json[attr].length;
value=json[attr][0];
}
}
alert("出現(xiàn)最多的字符是:"+value+',出現(xiàn)次數(shù)是:'+num);
};
max(str);

如果不想往json里放東西怎么做呢?

分析:

1.準(zhǔn)備一個(gè)空的json,通過(guò)循環(huán)字符串的每個(gè)字符來(lái)看,如果json里沒(méi)有這個(gè)字符,就把這個(gè)字符的數(shù)目設(shè)為1,如果有則數(shù)目++

2.循環(huán)json里的字符,只要存在,就把他的數(shù)目賦給一個(gè)變量,并且每次都比較新的字符數(shù)量和這個(gè)變量的大小,如果比變量大,則更新變量的值,最后這個(gè)變量的值就是最多字符的數(shù)目

而最多的字符就是json里這個(gè)字符

var str="sssfgtdfssddfsssfssss";
function max(){
var json={};
for(var i=0;i<str.length;i++){
var k=str[i]; //k是所有字符,字符串也跟數(shù)組一樣可以通過(guò)中括號(hào)下標(biāo)方法取到每個(gè)子元素
if(json[k]){
json[k]++; //json里有這個(gè)字符時(shí),把這個(gè)字符的數(shù)量+1,
}
else{
json[k]=1; //否則把這個(gè)字符的數(shù)量設(shè)為1
}
}
var num=0;
var value=null;
for(var k in json){ //s、f、g、t、d
if(json[k]>num){
num=json[k];
value=k;
}
}
alert("出現(xiàn)最多的字符是:"+value+',出現(xiàn)次數(shù)是:'+num);
};
max(str); 

正則的方法

分析:

1.字符串轉(zhuǎn)為數(shù)組進(jìn)行排序,以便正則選出相同的挨在一起的字符

2.通過(guò)正則replace()方法的兩個(gè)參數(shù),來(lái)匹配出現(xiàn)最多的字符和數(shù)量

var str="sssfgtdfssddfsssfssss";
var num=0;
var value=null;
function max(){
var new_str=str.split("").sort().join("");
var re=/(\w)\1+/g; //沒(méi)有\(zhòng)1,re就是一整個(gè)排好序的字符串,有了\1就是出現(xiàn)過(guò)的有重復(fù)的取出來(lái),\1表示跟前面第一個(gè)子項(xiàng)是相同的
new_str.replace(re,function($0,$1){ //$0代表取出來(lái)重復(fù)的一個(gè)個(gè)整體,如[s,s...],[f,f..],[d,d....] $1代表這個(gè)整體里的字符
if(num<$0.length){
num=$0.length;
value=$1
}
});
alert(value+":"+num)
};
max(str);

相關(guān)文章

最新評(píng)論