JS算法:統(tǒng)計(jì)字符

1. 題目

請(qǐng)讀取出arr字符串中每個(gè)字母重復(fù)出現(xiàn)的次數(shù)分別是多少?如字符串a(chǎn)rr="abcdaabc",a重復(fù)出現(xiàn)3次,b重復(fù)出2次,c重復(fù)出2次,d重復(fù)出1次。

2. 算法

  1. 定義記錄出現(xiàn)字符的數(shù)組chars和字符出現(xiàn)次數(shù)的數(shù)組counts
  2. 遍歷字符串的每一個(gè)字符
  3. 判斷字符是否已經(jīng)存在chars,如果存在,則相應(yīng)計(jì)數(shù)加一;否則,把字符添加到chars中,counts相應(yīng)增加數(shù)據(jù)1

3. 代碼

var arr = "abcdaabc";

// 記錄字符
var chars = [];
// 記錄字符出現(xiàn)次數(shù)
var counts=[];

// 遍歷字符串每一個(gè)字符
for( var i in arr ){
  // 獲取字符位置
  var index = chars.indexOf(arr.charAt(i));
  
  if(-1==index){
    // 如果不存在
    chars.push(arr.charAt(i));// 保存新的字符
    counts.push(1); // 新的字符計(jì)數(shù)設(shè)為1
  }else{
    // 如果存在,對(duì)應(yīng)計(jì)數(shù)加一
    counts[index]++;
  }
}

// 測試:打印結(jié)果
for( var i in chars ){
  document.write("字符"+chars[i]+"出現(xiàn)"+counts[i]+"次 ");
}

4. 優(yōu)化

一般處理都是作為函數(shù),所以我們可以把上面的處理做成函數(shù)。
輸入值為字符串,輸出值為結(jié)果對(duì)象。

function countStr(){
// 記錄字符
var chars = [];
// 記錄字符出現(xiàn)次數(shù)
var counts=[];

// 遍歷字符串每一個(gè)字符
for( var i in arr ){
  // 獲取字符位置
  var index = chars.indexOf(arr.charAt(i));
  
  if(-1==index){
    // 如果不存在
    chars.push(arr.charAt(i));// 保存新的字符
    counts.push(1); // 新的字符計(jì)數(shù)設(shè)為1
  }else{
    // 如果存在,對(duì)應(yīng)計(jì)數(shù)加一
    counts[index]++;
  }
}
return {
 chars : chars,
 counts:counts
};
}
// 測試
var arr = "abcdaabc";
var res = countStr(arr); 
for( var i in res.chars ){
  document.write("字符"+res.chars[i]+"出現(xiàn)"+res.counts[i]+"次 ");
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • PHP常用函數(shù)大全 usleep() 函數(shù)延遲代碼執(zhí)行若干微秒。 unpack() 函數(shù)從二進(jìn)制字符串對(duì)數(shù)據(jù)進(jìn)行解...
    上街買菜丶迷倒老太閱讀 1,510評(píng)論 0 20
  • php usleep() 函數(shù)延遲代碼執(zhí)行若干微秒。 unpack() 函數(shù)從二進(jìn)制字符串對(duì)數(shù)據(jù)進(jìn)行解包。 uni...
    思?jí)鬚HP閱讀 2,146評(píng)論 1 24
  • 今天2016年10月29日,我在花溪,7點(diǎn)鐘的我剛從讓人陶醉的小夢(mèng)中醒來,肚子好難受啊,恩,喝一杯熱水就好了,剛...
    茶與安生閱讀 462評(píng)論 0 1
  • 六月新入會(huì):24 名單:0 推薦:0 跟進(jìn):全部完成 溫暖:2 感受:今天開始給自己制定了21的運(yùn)動(dòng)減肥計(jì)劃,打造...
    周曼Melaleuca閱讀 149評(píng)論 0 0
  • 新中國成立以來,恐怕沒有哪一個(gè)歷史時(shí)期像今天一樣,讓全中國的國民們自上而下的熱議反腐敗的問題,一部主旋律的電視劇作...
    易郁生閱讀 1,519評(píng)論 11 15

友情鏈接更多精彩內(nèi)容