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入门到精通教程
查看: 541|回复: 0

[算法学习]利用KMP求子串在母串中出现次数

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-12-1 00:05:55 | 显示全部楼层 |阅读模式
    1. import java.io.*;
    2. /** * @author iChuan * */
    3. public class KMP {
    4. private static String a;
    5. private static String b;
    6. private static int[] p;  
    7. /**  * 从标准输入读取a串和b串
    8.   * @param args
    9.   * @throws IOException
    10.   */
    11.    public static void main(String args[]) throws IOException{
    12.     System.out.println("Input the content string:");
    13.      BufferedReader stdin = new BufferedReader(new InputStreamReader(System.in));
    14.      a = stdin.readLine();  //a="abcabcabcabcdabcxabcabc"
    15.      System.out.println("And the string you want to search:");
    16.      b = stdin.readLine();
    17.      //b="abcabc";
    18.      KMP.Next();
    19.      for(int i=0;i< b.length();i++)
    20.          System.out.print(b.charAt(i)+"  ");
    21.      System.out.println();
    22.      for(int i=0;i< p.length;i++)
    23.          System.out.print(p[i]+"  ");
    24.      System.out.println();
    25.      KMP.match();
    26.    }
    27.    public  static void Next() {//建立模式串P的next[]表
    28.     p = new int[b.length()];
    29.     int j = 0;//“主”串指针
    30.     int t = p[0] = -1;//“模式”串指针
    31.     while (j < b.length()-1)
    32.         if (0 > t || b.charAt(j) == b.charAt(t)) {//匹配
    33.            j++; t++;
    34.            p[j] = t;
    35.         } else//失配
    36.            t =p[t];
    37.     }
    38.      /**
    39.       * 开始在a串中寻找b串的匹配,每找到一个就打印出对应a中的索引
    40.       */
    41.      public static void match(){
    42.        int j = -1;
    43.        for (int i = 0; i < a.length(); i++){
    44.         while (j > 0 && (b.charAt(j + 1) != a.charAt(i)))
    45.          j = p[j];
    46.         if (b.charAt(j + 1) == a.charAt(i))  
    47.          j++;
    48.         if (j + 1 == b.length()){
    49.          System.out.println("matched at " + String.valueOf(i + 1 - b.length()));
    50.          j = -1;
    51.          i=i-b.length()+2;
    52.         }
    53.       }
    54.       System.out.println("All done!");
    55.     }
    56. }
    复制代码
    运行:
    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!

      


    源码下载:http://file.javaxxz.com/2014/12/1/000555156.zip
    回复

    使用道具 举报

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

    本版积分规则

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

    GMT+8, 2025-2-25 04:19 , Processed in 0.360151 second(s), 46 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

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