模板

Trie

HIHOCODER1014
static final int N = (int)1e5+10;
static final int SIGMA=(int)27;
static int ch[][]=new int[N*10][SIGMA],sz;
static int var[]=new int[N*10];
static void insert(String x){
int u=0;
for(int i=0;i<x.length();i++){
int c=x.charAt(i)-'a';
if(ch[u][c]==0){
for(int t=0;t<SIGMA;t++){
ch[sz][t]=0;
}
ch[u][c]=sz;
var[sz++]=0;
}
u=ch[u][c];
var[u]++;
}
}
static int search(String x){
int u=0;
for(int i=0;i<x.length();i++){
int c=x.charAt(i)-'a';
if(ch[u][c]!=0) u=ch[u][c];
else return 0;
}
return var[u];
}
static void clear() {
sz=1;var[0]=0;
for(int i=0;i<SIGMA;i++) {
ch[0][i]=0;
}
}

KMP

HIHOCODER 1015

写法1

     static void getFail(char[] b) {
int m=b.length,j=0;
f[0]=f[1]=0;
for(int i=1;i<m;i++) {
while(j>0&&b[j]!=b[i]) j=f[j];
if(b[j]==b[i]) j++;
f[i+1]=j;
}
}
static int kmp_count(char[] a,char[] b) {
int n=a.length,m=b.length;
int j=0,res=0;
for(int i=0;i<n;i++) {
while(j>0&&b[j]!=a[i]) j=f[j];
if(b[j]==a[i]) j++;
if(j==m) {
j=0;
res++;
}
}
return res;
}

写法2

    static void getFail(char[] b,int m) {
int j=0;
f[1]=0;
for(int i=2;i<=m;i++) {
while(j>0&&b[j+1]!=b[i]) j=f[j];
if(b[j+1]==b[i]) j++;
f[i]=j;
}
}
static int kmp_count(char[] a,char[] b,int n,int m) {
int j=0,res=0;
for(int i=1;i<=n;i++) {
while(j>0&&b[j+1]!=a[i]) j=f[j];
if(b[j+1]==a[i]) j++;
if(j==m) {
j=0;
res++;
}
}
return res;
}

Manacher

HIHOCODER1016
static final int N=(int)1e6+10;
static char a[]=new char[N],str[]=new char[2*N+5];
static int p[]=new int[2*N+5],len1,len2;
static void Init(){
len1=a.length;
str[0]='(';
str[1]='#';
for(int i=0;i<len1;i++){
str[i*2+2]=a[i];
str[i*2+3]='#';
}
len2=len1*2+2;
str[len2]=')';
}
static int Manacher(){
for(int i=0;i<len2;i++) p[i]=0;
int id=0,mx=0,ans=0;
for(int i=1;i<len2;i++){
if(mx>i) p[i]=Math.min(mx-i,p[2*id-i]);
else p[i]=1;
for(;str[i+p[i]]==str[i-p[i]];p[i]++);
if(p[i]+i>mx){
mx=p[i]+i;
id=i;
}
if(p[i]-1>ans) ans=p[i]-1;
}
return ans;
}

Tire图

HIHOCODER 1036
static int sz;
static final int N=1000005;
static class Node{
Node(){
post = 0;
for(int i = 0; i < 26; i++)
next[i] = 0;
end = false;
}
int post;
int next[]=new int[26];
boolean end;
}; static Node nodes[]=new Node[N];
//将str添加到trie图中
static void insert(String str){
int cur=0;
for(int i=0;i<str.length();i++){
if(nodes[cur].next[str.charAt(i)-'a'] == 0)
nodes[cur].next[str.charAt(i)-'a'] = ++sz;
cur = nodes[cur].next[str.charAt(i)-'a'];
}
nodes[cur].end = true;
}
//为trie图中的每个点添加它指向的后缀点位置
static void addPost(){
LinkedList<Integer> que = new LinkedList<Integer>();
que.push(0);
int cur;
while(!que.isEmpty()){
cur=que.pop();
for(int i=0;i<26;i++){
if(nodes[cur].next[i]!=0){
que.push(nodes[cur].next[i]);
if(cur != 0)//不是根结点,需要设置当前点的子节点的后缀=父结点的后缀经过i到达的点
nodes[nodes[cur].next[i]].post = nodes[nodes[cur].post].next[i];
}
else //nodes[current].next[i] == -1当前点经过i没有可达的
nodes[cur].next[i] = nodes[nodes[cur].post].next[i];
}
}
} //查找str
static boolean search(String str){
int cur = 0;
for(int i=0;i<str.length();i++){
if(nodes[nodes[cur].next[str.charAt(i)-'a']].end)
return true;
cur = nodes[cur].next[str.charAt(i)-'a'];
}
return false;
}
static void Init() {
sz=0;
for(int i=0;i<=1000000;i++) {
nodes[i]=new Node();
}
}

ACM模板(Java)的更多相关文章

  1. ACM之Java速成(4)

    ACM中Java.进制转换 Java进制转换: 由于Unicode兼容ASCII(0-255),因此,上面得到的Unicode就是ASCII. java中进行二进制,八进制,十六进制,十进制间进行相互 ...

  2. ACM之Java速成(3)

    ACM中Java.大数处理 先上个代码: import java.math.*; import java.util.*; class Main{ public static void main(Str ...

  3. ACM之Java速成(2)

    acm中Java的应用 Chapter I. Java的优缺点各种书上都有,这里只说说用Java做ACM-ICPC的特点: (1) 最明显的好处是,学会Java,可以参加Java Challenge ...

  4. ACM中java的使用

    ACM中java的使用 转载自http://www.cnblogs.com/XBWer/archive/2012/06/24/2560532.html 这里指的java速成,只限于java语法,包括输 ...

  5. ACM之Java输入输出

    本文转自:ACM之Java输入输出 一.Java之ACM注意点 1. 类名称必须采用public class Main方式命名 2. 在有些OJ系统上,即便是输出的末尾多了一个“ ”,程序可能会输出错 ...

  6. ACM中java的使用 (转)

    ACM中java的使用 这里指的java速成,只限于java语法,包括输入输出,运算处理,字符串和高精度的处理,进制之间的转换等,能解决OJ上的一些高精度题目. 1. 输入: 格式为:Scanner ...

  7. [工具使用]-利用latex管理创建自己的ACM模板

    从很早入坑ACM开始,便和各种算法的模板打着交道,虽然kaungbin的模板已经足够强大,但是自己在平常做题中也逐渐有着自己的一些模板,也有一些kuangbin模板中没有的更快的板子,虽然不确定时候以 ...

  8. ACM中Java的应用

    先说一下Java对于ACM的一些优点吧: (1) 对于熟悉C/C++的程序员来说Java 并不难学,两周时间基本可以搞定一般的编程,再用些时间了解一下Java库就行了.Java的语法和C++非常类似, ...

  9. ZOJ ACM 1204 (JAVA)

    毕业好几年了,对算法还是比較有兴趣,所以想又一次開始做ACM题.俺做题比較任意,一般先挑通过率高的题来做. 第1204题,详细描写叙述请參考,ZOJ ACM 1204 1)难度分析 这个题目,基本的难 ...

随机推荐

  1. AForge.net简介和认识

    AForge.NET是一个专门为开发者和研究者基于C#框架设计的,他包括计算机视觉与人工智能,图像处理,神经网络,遗传算法,机器学习,模糊系统,机器人控制等领域.这个框架由一系列的类库组成.主要包括有 ...

  2. Robot Framework操作mongodb数据库

    RF对mongodb操作需要安装以下两个库: 1.pymongo 可以采用pip install pymongo: (如果下载过慢,可指定下载源,如:http:pypi.douban.com/simp ...

  3. excel导入phpmyadmin

    1.将excel文件另存为txt文件,再将txt文件保存为.csv文件同时修改编码为UTF8 2.登录phpmyadmin,在phpmyadmin中创建好表格,按excel中的顺序创建每列 3.因为p ...

  4. 学习JavaScript数据结构与算法 (二)

    学习JavaScript数据结构与算法 的笔记 包含第四章队列, 第五章链表 本人所有文章首发在博客园: http://www.cnblogs.com/zhangrunhao/ 04队列 实现基本队列 ...

  5. shell随机数生成

    shell中的RANDOM变量: echo  $RANDOM 加上系统时间更加随机:echo `date +%N`$RANDOM | md5sum |cut -c1-8 通过/dev/urandom ...

  6. RHEL6.5----LVS(NAT)

    主机名 IP  所需软件  master 192.168.30.130(Nat) 192.168.17.130(VMnet4) ipvsadm  node-1 192.168.17.131  http ...

  7. 十个非常棒的学习angularjs的英文网站

    AngularJS 是非常棒的JS框架,能够创建功能强大,动态功能的Web app.AngularJS自2009发布以来,已经广泛应用于Web 开发中.但是对想要学习Angular JS 的人而言,只 ...

  8. Apache Cordova

    http://cordova.apache.org/ Apache Cordova is a platformfor building native mobile applications using ...

  9. 安卓自定义View教程目录

    基础篇 安卓自定义View基础 - 坐标系 安卓自定义View基础 - 角度弧度 安卓自定义View基础 - 颜色 进阶篇 安卓自定义View进阶 - 分类和流程 安卓自定义View进阶 - Canv ...

  10. laravel中的队列

    Laravel 队列为不同的后台队列服务提供统一的 API,可使用多种驱动,eg:mysql,redis,Beanstalkd等,驱动已经封装,不需要管理这些驱动,只需要修改配置就可以更改驱动,在驱动 ...