给定字符串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