任务描述
编写一个程序,记录一个字串,在整串中出现的次数,例如记录字串“nba”在整串“nbahjdfahsjhdjanbasjhdj”中出现的次数。要求使用String类的常用方法来计算出现的次数。
任务目标
分析任务设计思路
根据思路独自完成
掌握String类的常用方法
实现思路
1.我们需要得到两个字符串,一个整串,一个子串。
2.查询子串在整串中出现的次数,可以使用String类的contains()方法,判断整串中是否包含子串,如果不包含,则不用计算,子串在整串中出现次数为零。
3.若是包含,则使用String类的indexOf()方法,获取子串在第一次出啊先的索引。获取之后,在整串中该索引加上子串长度的位置出继续查找子串。直到循环完成,找不到子串为止。此时的indexOf()方法的返回值为-1.
4.定义一个计数器,记录出现的次数,在循环中没查到一次子串,则计数器加一。
实现代码
public class StringTest {
public static void main(String[] args) {
String str = "nbahjdfahsjhdjanbasjhdj";
String key = "nba";
int count = getKeyStringCount(str,key);
System.out.println("count="+count);
}
public static int getKeyStringCount(String str, String key) {
//定义计数器记录出现位置
int count = 0;
//若是不包含子字符串
if (!str.contains(key)){
return count;
}
//记录子字符串出现的位置
int index = 0;
while ((index = str.indexOf(key)) != -1){
str = str.substring(index + key.length());
count++;
}
return count;
}
}
count=2
思考:
首先我在主方法里定义了两个字符串,一个用作主字符串,我取了str作为变量名字,子字符串我用key作为变量名字。当然之后我们学习输入Scanner时,我们可以通过输入的两个字符串来更新这个方案。
我得到字符串之后,定义了一个返回值为int类型的方法getKeyStringCount(翻译一下就是得到子字符串出现的次数)来获取子字符串出现的个数。
同时传入两个参数,分别为str主字符,key子字符串,来进行使用。
第一步我们要先判断有没有子字符串,若无,则直接返回count的初始值0;
第二步:首先找到子字符串出现的位置,通过定义一个变量index来接收子字符串出现的索引位置,找到索引位置后,执行下面的语句,当然若是没有子字符串会得到-1,因此我们需要让索引等于-1时跳出循环。
第三步:我们得到了子字符串开始出现的索引位置,此时我们只需要将出现子字符串索引位置加上子字符串的长度,然后将出现子字符串之前的字符串截去就可以找下一个字符串了。截取完成后,代表我们找到了一个字符串,因此count的值加一,记作count++。
第四步:我们返回值,或者得到的值是什么呢?没错就是count计数的值,因此我们方法需要返回值的类型是int 虽然我们传递的参数均是String类型。
在开始编写程序时,会出现红色的错误提示,也是由此而来。
温馨提示:若是对程序执行有疑问的小伙伴,可以通过debug的方式来查看程序的执行流程,看看各组数据的变化情况,自己思考如此变化的原因。
本次小任务到此结束,之后还要多加练习。