【算法java版08】:获取一个字符串在另一个字符串中出现的次数,比如“ab”在“abcdeabdeabababdab”中出现的次数

获取一个字符串在另一个字符串中出现的次数,比如“ab”在“abcdeabdeabababdab”中出现的次数

一、题目描述

给定两个任意字符串,获取一个字符串在另一个字符串中出现的次数,比如“ab”在“abcdeabdeabababdab”中出现的次数

二、解题思路

  • 方式一:使用String的indexOf(String str) 方法遍历寻找并记录子字符串在目标字符串中首次出现的位置,并存入index变量中,然后使用String的substring() 方法从 (index + 子字符串的长度)位置 开始截取目标字符串到最后一个字符。直到indexOf(String str)方法返回 -1 ,即无法从目标字符串中找到待匹配的子字符串时,结束循环。
  • 方式二:通过String的indexOf(String str,int fromIndex)方法,来遍历寻找子字符串在目标字符串中出现的次数,每当找到一次子字符串,就让 fromIndex 加上 子字符串的长度。直到indexOf(String str,int fromIndex)方法返回 -1 ,即无法从目标字符串中找到待匹配的子字符串时,结束循环。
  • 说明:index 在每次找到子字符串后都要加上 子字符串的长度 的原因是为了从已经找到的子字符串的后边接着去寻找,防止发生重复寻找。

三、代码示例

package com.commonclass.exercise02;

import org.junit.Test;

/**
 * @ClassName StringDemo02
 * @Description 获取一个字符串在另一个字符串中出现的次数,比如“ab”在“abcdeabdeabababdab”中出现的次数
 * @Author wk
 * @Date 2021/12/9 20:00
 * @Version 1.0
 */
public class StringDemo02 {

    public int getCount(String mainStr, String subStr) {
        int mainLength = mainStr.length();
        int subLength = subStr.length();
        int count = 0;
        int index = 0;
        if (mainLength >= subLength) {
            // 方式一
//            while ((index = mainStr.indexOf(subStr)) != -1) {
//                count++;
//                mainStr = mainStr.substring(index + subStr.length());
//            }
            // 方式二
            while((index = mainStr.indexOf(subStr,index)) != -1){
                count++;
                index += subLength;
            }
            return count;
        } else {
            return 0;
        }
    }
    @Test
    public void test() {
        String str1 = "AB";
        String str2 = "ABABABCDEFFABABDDDDEEEEFFFAAAAA";
        int count = getCount(str2,str1);
        System.out.println(count); // count = 5
    }
}

四、测评结果

  • 测评用例:
 String str1 = "AB";
 String str2 = "ABABABCDEFFABABDDDDEEEEFFFAAAAA";

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

☆*往事随風*☆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值