String小练习3-获取一个字符串在另一个字符串中出现的次数

获取一个字符串在另一个字符串中出现的次数。

(例如:”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;
    }

}

你可能感兴趣的:(Java基础)