hdu 3336 Count the string

简介: 点击打开链接hdu 3336 思路:kmp+next数组的应用 分析: 1 题目要求的是给定一个字符串s,求字符串s的所有的前缀在s的匹配的次数之和mod10007. 2 很明显n1,为什么要从n开始而不是1开始呢,这里因为是要求前缀的匹配数而不是后缀; 4 求sum的时候注意每一步都有可能超过范围,所以就要求一次sum同时取模一次。

点击打开链接hdu 3336


思路:kmp+next数组的应用

分析:
1 题目要求的是给定一个字符串s,求字符串s的所有的前缀在s的匹配的次数之和mod10007.
2 很明显n<= 200000,分析一下那么就要n个前缀如果每一个前最都去匹配s的话复杂度就是o(n^2),那么肯定是TLE的,所以要考虑另外的思路
3 我们知道next[j] = len,表示的是在前j个字符里前缀和后缀的最大的匹配的长度为len,所以根据next数组的性质,我们只要去枚举j的值从n->1,为什么要从n开始而不是1开始呢,这里因为是要求前缀的匹配数而不是后缀;
4 求sum的时候注意每一步都有可能超过范围,所以就要求一次sum同时取模一次。

代码:

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;

#define MAXN 200010
#define MOD 10007

int t , n , sum;
int next[MAXN];
char pattern[MAXN];

void getNext(){
   next[0] = next[1] = 0;
   for(int i = 1 ; i < n ; i++){
      int j = next[i];
      while(j && pattern[i] != pattern[j])
          j = next[j];
      next[i+1] = pattern[i] == pattern[j] ? j+1 : 0;
   }
}

void solve(){
   sum = 0;
   for(int i = n ; i >= 1 ; i--){/*枚举i的值*/
      sum = (sum+1)%MOD;/*每一步取模*/
      int j = next[i];
      while(j){/*顺着nest数组求匹配的次数*/
         sum = (sum+1)%MOD;
         j = next[j];
      }
   }
   printf("%d\n" , sum);
}

int main(){
   scanf("%d" , &t);
   while(t--){
       scanf("%d" , &n);
       scanf("%s" , pattern);
       getNext();
       solve();
   }
   return 0;
}



目录
相关文章
|
JavaScript BI
HDU3336 Count the string 一道KMP的巧解
http://acm.hdu.edu.cn/showproblem.php?pid=3336 题目 这是喵呜大神用KMP做的,46MS  #include &lt;stdio.h&gt; #define MOD 10007 char b[200005]; int dp[200005]; int p[200005]; int n; int Pre() { int s,i,
1369 0
|
1天前
|
安全 Java 索引
带你快速掌握Java中的String类和StringBuffer类(详解常用方法 | 区别 )
带你快速掌握Java中的String类和StringBuffer类(详解常用方法 | 区别 )
|
4天前
|
存储 Java API
Java基础之String类
Java的String类是引用类型,用于创建和操作字符串。字符串对象在`java.lang`包中,不可变。创建方式包括字面量和`new`关键字。字符串池存储字符串常量,避免重复。比较字符串用`equals()`(区分大小写)和`equalsIgnoreCase()`(不区分大小写)。`length()`返回长度,`concat()`或`+`拼接,`substring()`截取,`indexOf()`和`lastIndexOf()`查找,`replace()`替换,`split()`分割。这些是常用的字符串API。
8 0
|
4天前
|
Java
Java基础之String类
Java基础之String类
8 0
|
7天前
|
存储 缓存 安全
java源码之String详解
java源码之String详解
11 0
|
8天前
|
Java 数据处理 Apache
探讨Java中判断String类型为空和null的方法
探讨Java中判断String类型为空和null的方法
12 1
|
9天前
|
Java UED
Java中String强转int:一种常见的错误和解决方法
在Java中将非数字字符串转换为整数会导致`NumberFormatException`。要解决这个问题,可以使用`try-catch`捕获异常,正则表达式验证数字格式,或利用异常信息提供错误提示。例如,`Integer.parseInt()`会因遇到非数字字符如`&quot;123abc&quot;`而抛出异常,但通过异常处理或正则`\\d+`可确保安全转换。记得在编程时避免直接强转,以防止程序异常中断。
|
10天前
|
Java API 索引
java中String类常用API
java中String类常用API
|
19天前
Failed to bind properties under ‘logging.level‘ to java.util.Map java.lang.String, java.lang.String
Failed to bind properties under ‘logging.level‘ to java.util.Map java.lang.String, java.lang.String
8 0
|
19天前
|
安全 Java 数据安全/隐私保护
Java基础4-一文搞懂String常见面试题,从基础到实战,更有原理分析和源码解析!(二)
Java基础4-一文搞懂String常见面试题,从基础到实战,更有原理分析和源码解析!(二)
21 0