Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 700|回复: 0

利用KMP求子串在母串中出现次数

[复制链接]

该用户从未签到

发表于 2011-9-18 13:47:52 | 显示全部楼层 |阅读模式
import java.io.*;
/** * @author iChuan * */
public class KMP {
private static String a;
private static String b;
private static int[] p;  
/**  * 从标准输入读取a串和b串
  * @param args
  * @throws IOException
  */
   public static void main(String args[]) throws IOException{
    System.out.println("Input the content string:");
     BufferedReader stdin = new BufferedReader(new InputStreamReader(System.in));
     a = stdin.readLine();  //a="abcabcabcabcdabcxabcabc"
     System.out.println("And the string you want to search:");
     b = stdin.readLine();
     //b="abcabc";
     KMP.Next();
     for(int i=0;i< b.length();i++)
         System.out.print(b.charAt(i)+"  ");
     System.out.println();
     for(int i=0;i< p.length;i++)
         System.out.print(p+"  ");
     System.out.println();
     KMP.match();
   }
   public  static void Next() {//建立模式串P的next[]表
    p = new int[b.length()];
    int j = 0;//“主”串指针
    int t = p[0] = -1;//“模式”串指针
    while (j < b.length()-1)
    if (0 > t || b.charAt(j) == b.charAt(t)) {//匹配
       j++; t++;
       p[j] = t;
    } else//失配
       t =p[t];
    }
     /**
      * 开始在a串中寻找b串的匹配,每找到一个就打印出对应a中的索引
      */
     public static void match(){
       int j = -1;
       for (int i = 0; i < a.length(); i++){
        while (j > 0 && (b.charAt(j + 1) != a.charAt(i)))
         j = p[j];
        if (b.charAt(j + 1) == a.charAt(i))  
         j++;
        if (j + 1 == b.length()){
         System.out.println("matched at " + String.valueOf(i + 1 - b.length()));
         j = -1;
         i=i-b.length()+2;
        }
      }
      System.out.println("All done!");
    }
}
运行:
C:\work>java KMP
Input the content string:
abcabcabcabcdabcxabcabc
And the string you want to search:
abcabc
a b c a b c
-1 0 0 0 1 2
matched at 0
matched at 3
matched at 6
matched at 17
All done!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2025-1-10 23:39 , Processed in 0.402800 second(s), 46 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表