給定字符串oabcoefoxyozzopp
,要求輸出字符o
出現的位置和次數。算法
indexOf
返回的結果,若不是-1,則繼續日後查找indexOf
只能查找到第一個,因此後面的查找,利用第二個參數,在當前索引加1,str.indexOf('o', index + 1)
,從而繼續查找var str = "oabcoefoxyozzopp"; var index = str.indexOf('o'); // 先找到第一個o的位置,幅值給index var num = 0; // num表示o出現的次數 while (index !== -1) { // 若是index不等於-1表示還沒查找完,則繼續查找 // 若index等於-1,則表示當前索位置以後沒有o了,退出循環 console.log(index); // 輸出當前的位置 num++; index = str.indexOf('o', index + 1); // 在當前的索引位置+1,從新賦值給index,從後一個位置繼續查找 } console.log('「o」出現的次數是: ' + num);
0
4
7
10
13
「o」出現的次數是: 5