統計用戶輸入字串中各字符出現的次數,
例如:輸入字串為”abca12abbc121d”,輸出為:a出現3次,b出現3次,c出現2次,d出現1次,1出現3次,2出現2次,
方法一
<script>
var ary ="abca12abbc121d";
var obj = {};
var i = 0;
ary1 = ary.toLocaleLowerCase();
for(i = 0; i < ary1.length; i++)
{
key = ary1[i];
if(obj[key])
{
//物件中有這個字母
obj[key]++;
}
else
{
//物件中沒有這個字母,把字母加到物件中
obj[key] = 1;
}
}
for(var key in obj) //遍歷這個物件
{
console.log(key + "這個字符出現了" + obj[key] + "次");
}
</script>
效果如下:

這個方法是利用了開發者工具來實作的
方法二
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="sc/char-sunmmary.js"></script>
<script>
window.onload=function(){
var txtChars=document.getElementById("txt-chars");
var show=document.getElementById("show");
document.getElementById("btn-ok").onclick=function(){
var str=txtChars.value;
var charTotal=total(str);
// 降序
charTotal.sort(function(a,b){
return (a.count-b.count)*-1;
})
show.innerHTML="<ul>";
//slice(0,5)取前五
for(var ct of charTotal.slice(0,5)){
show.innerHTML+="<li>"+ct.char+"出現了"+ct.count+"次</li>";
}
show.innerHTML+="</ul>";
}
}
</script>
</head>
<body>
<label for="txt-chars">請輸入一串字符:</label>
<input type="text" id="txt-chars" name=""/>
<button id="btn-ok">確定</button>
<p id="show"></p>
</body>
</html>
char-sunmmary.js
function Summary(char,count) {
this.char=char;
this.count=count;
}
// 傳遞字串,回傳出現頻率
function total(str) {
var result=[];
for(var c of str){
var charObj=checkChar(result,c);
if(charObj==null){
result.push(new Summary(c,1));
}
else{
charObj.count++;
}
}
return result;
}
// 在陣列arr中查找包含字符char的summary實列
//如果存在,則回傳該實體,否則回傳null
function checkChar(arr,char) {
var r=null;
for(var c of arr){
if(c.char==char){
r=c;
break;
}
}
return r;
}

以上為止
轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/265944.html
標籤:其他
上一篇:CSS基礎:Flex基本屬性
