一个子串在整串中出现的次数

思想一:

1.声明次数count=0;
 * 2.计算子串的长度。
 * 3.按照子串的长度,从整串的开始位置开始搜索,判断子串长度个字符,看是否与子串相同,
 *   若相同,count+1.
 * 4.搜索位置+1;知道搜索位置等于整串.length-子串.length结束搜索。
 * 5.输出count。
 */
public class StringTest {


/**
* @param args
*/
public static int computeCount(String str, String substr)
{
int count=0;
for(int i=0;i<=str.length()-substr.length();i++)
{
String str2=str.substring(i,i+substr.length());
if(str2.contains(substr))
count++;
}
return count;
}
public static void main(String[] args) {
// TODO Auto-generated method stub
        String str="nbaernbanbatynbauinbaopnba";
        String substr="nba";
        int count=computeCount(str,substr);
        System.out.println(substr+"在"+str+"中出现了"+count+"次");
}


}

思想二:

1.定义出现次数count=0;
 * 2.确定整串的搜索位置,从index=0开始,通过indexOf获取子串第一次出现的位置index,count+1。
 * 3.接下来搜索位置index=index+子串.长度。
 * 4.搜索直到indexOf()返回-1.搜索结束。

public class StringTest2 {


public static int computeCount(String str, String key)
{
int count=0;
int index=0;
while((index=str.indexOf(key,index))!=-1)
{
count++;
index=index+key.length();
}

return count;
}
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
String str="nbaernbanbatynbauinbaopnba";
       String substr="nba";
       int count=computeCount(str,substr);
       System.out.println(substr+"在"+str+"中出现了"+count+"次");
}


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值