Java、模式匹配

 

package algorithm;

import java.util.Scanner;

/**
 * @author: xyz
 * @create: 2022/8/11
 * @Description:
 * @FileName: Exercise22_03
 * @History:
 * @自定义内容:模式匹配
 */
public class Exercise22_03 {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        System.out.print("Enter a string s1: ");
        String s1 = input.nextLine();

        System.out.print("Enter a string s2: ");
        String s2 = input.nextLine();

        int index = indexOf(s1, s2);s2.indexOf(s1);
        System.out.println((index == -1 ? "Not " : "") + "matched at index " + index);
    }

    /** 模式匹配-s2是否是s1的子串 */
    public static int indexOf(String s1, String s2) {
        if (s2.length() > s1.length())  //s2长度大于s1长度,非子串
            return -1;

        int i =0, j = 0;    //s1起始下标、s2起始下标
        while (i < s1.length() && j < s2.length()) {
            if (s1.charAt(i) == s2.charAt(j)) { //匹配字符
                i++; j++;
            } else {    //不匹配字符
                i = i - j + 1;
                j = 0;
            }

            //匹配成功,退出循环
            if (j == s2.length()) break;
        }

        //匹配成功,返回下标,否则返回-1
        return j >= s2.length() ? i - s2.length() : -1;
    }
}

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值