831. KMP字符串(模板)
给定一个模式串S,以及一个模板串P,所有字符串中只包含大小写英文字母以及阿拉伯数字。
模板串P在模式串S中多次作为子串出现。
求出模板串P在模式串S中所有出现的位置的起始下标。
输入格式
第一行输入整数N,表示字符串P的长度。
第二行输入字符串P。
第三行输入整数M,表示字符串S的长度。
第四行输入字符串S。
输出格式
共一行,输出所有出现位置的起始下标(下标从0开始计数),整数之间用空格隔开。
数据范围
1≤N≤1041≤N≤104
1≤M≤1051≤M≤105
输入样例:
3
aba
5
ababa
输出样例:
0 2
ne[i]的含义:对于子串,最长相同前缀和后缀的长度
eg:
abaacdffgab ne[i] 0 0 1 1 0 0 0 0 0 1 2
代码:
import java.util.Scanner;
public class Main{
        static int m,n;//n为子串,m为父串
        static int ne[]=new int[10005];
        static char p[]=new char[10005];
         static char s[]=new char[100005];
        static void get_next(){
                for(int i=2,j=0;i<=n;i++){//i从2开始,如果i=1就不匹配,那么ne[1]=0
                        while(j>0 &&p[i]!=p[j+1]) j=ne[j];
                        if(p[i]==p[j+1]) j++;
                        ne[i]=j;
                }
        }
        static void kmp(){
                for(int i=1,j=0;i<=m;i++){
                    while(j>0 && s[i]!=p[j+1]) j=ne[j];
                    if(s[i]==p[j+1]) j++;
                    if(j==n){
                        System.out.print((i-n)+" ");
                        j=ne[j];
                    }
                }
        }
        public static void main(String[] args) {
                 Scanner scan=new Scanner(System.in);
                 n=scan.nextInt();
                 String sn=scan.next();
                 m=scan.nextInt();
                 String sm=scan.next();
                 for(int i=1;i<=n;i++) p[i]=sn.charAt(i-1);//子串
                 for(int i=1;i<=m;i++) s[i]=sm.charAt(i-1);//父串
                 get_next();
                 kmp();
        }
}
831. KMP字符串(模板)的更多相关文章
- AcWing 831. KMP字符串(模板)
		给定一个模式串S,以及一个模板串P,所有字符串中只包含大小写英文字母以及阿拉伯数字. 模板串P在模式串S中多次作为子串出现. 求出模板串P在模式串S中所有出现的位置的起始下标. 输入格式 第一行输入整 ... 
- 831. KMP字符串
		给定一个模式串S,以及一个模板串P,所有字符串中只包含大小写英文字母以及阿拉伯数字. 模板串P在模式串S中多次作为子串出现. 求出模板串P在模式串S中所有出现的位置的起始下标. 输入格式 第一行输入整 ... 
- ACW:831. KMP字符串
		感觉这道题非常有意思,学的过程中觉得及难,学完之后觉得及简单,看y总的视频没有看懂...,因此自己找了一篇博文理解并完成题目. import java.io.*; /** * @author admi ... 
- AcWing 831. KMP字符串
		#include <iostream> using namespace std; , M = ; int n, m; int ne[N];//ne[i] : 以i为结尾的部分匹配的值 ch ... 
- KMP算法,匹配字符串模板(返回下标)
		//KMP算法,匹配字符串模板 void getNext(int[] next, String t) { int n = next.length; for (int i = 1, j = 0; i & ... 
- KMP字符串模式匹配详解(zz)
		刚看到位兄弟也贴了份KMP算法说明,但本人觉得说的不是很详细,当初我在看这个算法的时候也看的头晕昏昏的,我贴的这份也是网上找的.且听详细分解: KMP字符串模式匹配详解 来自CSDN A_B_ ... 
- hdu 1711 KMP算法模板题
		题意:给你两个串,问你第二个串是从第一个串的什么位置開始全然匹配的? kmp裸题,复杂度O(n+m). 当一个字符串以0为起始下标时.next[i]能够描写叙述为"不为自身的最大首尾反复子串 ... 
- KMP(模板)
		算法讲解: KMP算法最浅显易懂 模板来源: 从头到尾彻底理解KMP 首先:KMP的模板为: void get_next(char *a, int *nex) { nex[] = ; , j = ; ... 
- 代码片段 - JavaScript 字符串模板
		/* ------------------------------ // 字符串模板1,语法严格,不能混用,效率相对较高 // 使用 {{ }} 作为标记是为了允许在模板中使用 JSON 字符串 // ... 
随机推荐
- go并发版爬虫
			并发版爬虫 代码实现 /crawler/main.go package main import ( "learn/crawler/engine" "learn/crawl ... 
- PHP0013:PHP操作文件案例 遍历phpdamin目录
- Python学习课程零基础学Python
			python学习课程,零基础Python初学者应该怎么去学习Python语言编程?python学习路线这里了解一下吧.想python学习课程?学习路线网免费下载海量python教程,上班族也能在家自学 ... 
- 通过/dev/mem操作物理内存
			/dev/mem设备可以用来访问物理内存.下面一段应用程序的代码,实现了通过/dev/mem对物理内存空间中SRAM1的访问. #include <stdio.h> #include &l ... 
- SpringBoot整合NoSql--(一)Redis
			简介: Redis是一个开源的使用ANSI C语言编写.遵守BSD协议.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.它通常被称为数据结构服务器,因为值(v ... 
- jQuery---$冲突的解决方案
			$冲突的解决方案 遇到其他js文件也用$包装了函数.可以把jQuery放在后面,并释放下$的控制权,也可以换个字符替代原来的$,例如$$ 或者,jQuery //jQuery释放$的控制权 $$ = ... 
- equals和==的使用
			1.equals的使用: 引用数据类型的比较:通常情况下比较的是引用数据类型下的栈中的地址,但当你重写了equals方法后就不一定了 User user1=new User("tom&quo ... 
- BZOJ2005: [Noi2010]能量采集(欧拉函数)
			Description 栋栋有一块长方形的地,他在地上种了一种能量植物,这种植物可以采集太阳光的能量.在这些植物采集能量后, 栋栋再使用一个能量汇集机器把这些植物采集到的能量汇集到一起. 栋栋的植物种 ... 
- 服务治理框架:Spring Cloud Eureka
			最近在学习Spring Cloud的知识,现将服务治理框架 Spring Cloud Eureka 的相关知识笔记整理如下.[采用 oneNote格式排版] 
- Web_0005:阿里云服务器OSS权限的配置开通
			创建用户 1,创建子用户 2,点击新建用户 3,设置账号类型,可以同时选 设置权限 1,设置对阿里云模块的控制权限,如 oss ecs 等的访问控制权限 2,点击所需的权限 3,获取账号的Acess ... 
