day28. 找出字符串中第一个匹配项的下标

该文章介绍了一种解决编程问题的方法,通过滑动窗口策略来寻找目标字符串在源字符串中首次出现的位置。代码示例展示了一个Java解决方案,遍历字符串并对比字符,当找到匹配的开始字符时,进一步检查是否完全匹配目标子串。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.题目描述

题目链接:28. 找出字符串中第一个匹配项的下标

 2.题解

用滑动窗口的方法来解决这个问题,用两个循环来实现

3.代码示例

class Solution {
    public int strStr(String haystack, String needle) {
        char[] hayChar=haystack.toCharArray();
        char[] neChar=needle.toCharArray();
        int first=0,index=0;
        for(int i=0;i<hayChar.length;i++){
            if(hayChar[i]==neChar[0]){
                index=i;
                int j=0;                
                while(index<hayChar.length&&j<neChar.length&&hayChar[index++]==neChar[j++]){
                    if(j==neChar.length)  
                        return i;
                }
            }
        }
        return -1;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值