获取一个字符串在另一个字符串中出现的次数。
(例如:”abkkcdkkefkkskk”)
思路:
- 1.定义个计数器。
- 2.获取kk第一次出现的位置。
- 3.从第一次出现位置后剩余的字符串中继续获取kk出现的位置。
每获取一次就计数一次。 - 4.当获取不到时,计数完成。
public class StringDemo04 {
public static void main(String[] args) {
String str = "kkabkkcdkkefkks";
System.out.println("count====="+str.split("kk").length);//不建议使用
//方式一和方式二,建议使用方式二, 不用每次都重新获取一个新的字符串,减少内存
System.out.println("count="+getSubCount_1(str,"kk"));
System.out.println("count="+getSubCount_2(str,"kk"));
}
//方式一
public static int getSubCount_1(String str,String key){
int count = 0;//计数
int index = 0;//索引
while((index=str.indexOf(key))!=-1){
System.out.println("str="+str);
str = str.substring(index+key.length());//从出现的位置开始截取,形成新的字符串,再循环截取
count++;//截取一次,计数一次
}
return count++;
}
//方式二
public static int getSubCount_2(String str,String key){
int count = 0;
int index = 0;
while((index=str.indexOf(key,index))!=-1){
System.out.println("index="+index);
index = index+key.length();//根据在字符串中出现的位置,计数一次,下次从该位置后重新查找出现新的位置
count++;
}
return count;
}
}