Gotta Write A Code
C++博客
::
首頁
::
新隨筆
::
聯系
::
聚合
::
管理
posts - 33, comments - 33, trackbacks - 0
<
2010年11月
>
日
一
二
三
四
五
六
31
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
1
2
3
4
5
6
7
8
9
10
11
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(5)
給我留言
查看公開留言
查看私人留言
隨筆分類
CUDA(1)
Windows Programming(4)
算法題解(22)
隨筆檔案
2012年5月 (1)
2012年3月 (9)
2011年11月 (4)
2011年10月 (1)
2011年9月 (1)
2011年7月 (1)
2011年6月 (3)
2011年5月 (1)
2011年4月 (1)
2011年3月 (2)
2011年1月 (2)
2010年12月 (1)
2010年11月 (6)
搜索
最新評論
1.?re: DX筆記[未登錄]
OrOrOrz!!
--diryboy
2.?re: 作品:動態語言AnyC 1.0
@so
其實里面的代碼存在bug...
--qqdy
3.?re: 作品:動態語言AnyC 1.0
游戲腳本高級編程的代碼很好啊。
--so
4.?re: 作品:動態語言AnyC 1.0
仰慕!!我剛開始學習編譯呢
--coreBugZJ
5.?re: AnyC:添加類型限制[未登錄]
Orz!!
--diryboy
閱讀排行榜
1.?逆序數及其求法(10790)
2.?Poj 3310 判環+度(5984)
3.?水文一篇--基于CUDA的矩陣相乘(4621)
4.?Poj2010 - 堆的應用(2484)
5.?水文:淺析PE File(2361)
評論排行榜
1.?作品:動態語言AnyC 1.0(4)
2.?poj 3074(3)
3.?ACM/ICPC杭州站 - hdu3680(3)
4.?水題四道 3-30(3)
5.?POJ Challenge - 2011.04.10部分題解(3)
hdu 2222 多模式串匹配
AC自動機用于多模式串匹配
1
#include
<
stdio.h
>
2
#include
<
string
.h
>
3
#include
<
queue
>
4
using
namespace
std;
5
6
const
int
N
=
500005
;
7
8
struct
Trie
9
{
10
int
flag;
11
int
fail;
12
int
next[
26
];
13
14
void
Init()
15
{
16
flag
=
0
;
17
fail
=
-
1
;
18
for
(
int
i
=
0
; i
<
26
;
++
i)
19
next[i]
=
0
;
20
}
21
}
;
22
23
Trie trieTrees[N];
24
int
treeCnt;
25
char
strs[
1000005
];
26
int
n;
27
28
void
Insert(
char
*
_str)
29
{
30
int
rt
=
0
;
31
while
(
*
_str
!=
0
)
32
{
33
int
t
=
*
_str
-
'
a
'
;
34
if
(trieTrees[rt].next[t]
==
0
)
35
{
36
trieTrees[
++
treeCnt].Init();
37
trieTrees[rt].next[t]
=
treeCnt;
38
}
39
rt
=
trieTrees[rt].next[t];
40
++
_str;
41
}
42
trieTrees[rt].flag
++
;
43
}
44
45
46
void
BFS()
47
{
48
queue
<
int
>
Queue;
49
int
rt
=
0
;
50
int
p,q;
51
Queue.push(
0
);
52
while
(
!
Queue.empty())
53
{
54
int
now
=
Queue.front();
55
Queue.pop();
56
for
(
int
t
=
0
; t
<
26
;
++
t)
57
{
58
if
(trieTrees[now].next[t])
59
{
60
p
=
trieTrees[now].fail;
61
q
=
trieTrees[now].next[t];
62
while
(p
!=-
1
&&
trieTrees[p].next[t]
==
NULL)
63
p
=
trieTrees[p].fail;
64
if
(p
==
-
1
)
65
trieTrees[q].fail
=
0
;
66
else
67
trieTrees[q].fail
=
trieTrees[p].next[t];
68
Queue.push(q);
69
}
70
}
71
}
72
}
73
74
int
Match(
char
*
_str)
75
{
76
int
ret
=
0
;
77
int
rt
=
0
;
78
int
t,p;
79
while
(
*
_str)
80
{
81
t
=
*
_str
-
'
a
'
;
82
if
(trieTrees[rt].next[t])
83
rt
=
trieTrees[rt].next[t];
84
else
85
{
86
p
=
trieTrees[rt].fail;
87
while
(p
!=
-
1
&&
(
!
trieTrees[p].next[t]))
88
p
=
trieTrees[p].fail;
89
if
(p
==
-
1
)
90
rt
=
0
;
91
else
92
rt
=
trieTrees[p].next[t];
93
}
94
p
=
rt;
95
while
(p
!=
0
&&
trieTrees[p].flag)
96
{
97
if
(trieTrees[p].flag)
98
{
99
ret
+=
trieTrees[p].flag;
100
trieTrees[p].flag
=
0
;
101
}
102
p
=
trieTrees[p].fail;
103
}
104
++
_str;
105
}
106
return
ret;
107
}
108
109
void
Test()
110
{
111
scanf(
"
%d
"
,
&
n);
112
treeCnt
=
0
;
113
trieTrees[
0
].Init();
114
for
(
int
i
=
0
; i
<
n;
++
i)
115
{
116
while
(gets(strs),strcmp(strs,
""
)
==
0
);
117
Insert(strs);
118
}
119
BFS();
120
gets(strs);
121
int
ret
=
Match(strs);
122
printf(
"
%d\n
"
,ret);
123
}
124
125
int
main()
126
{
127
//
freopen("data.txt","r",stdin);
128
int
testcase;
129
scanf(
"
%d
"
,
&
testcase);
130
for
(
int
i
=
0
; i
<
testcase;
++
i)
131
Test();
132
return
0
;
133
}
posted on 2012-03-29 18:15
bennycen
閱讀(1271)
評論(0)
編輯
收藏
引用
所屬分類:
算法題解
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
hdu 2087 hud 1686
hdu 2896 多模式串匹配2
hdu 2222 多模式串匹配
水題兩道
zoj 3542
poj 3074
逆序數及其求法
Poj 3310 判環+度
Poj 3104 二分答案
Poj1111 水題
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright ©2025 bennycen
人妻少妇久久中文字幕
|
久久久精品视频免费观看
|
免费精品久久天干天干
|
久久婷婷五月综合成人D啪
|
亚洲人成伊人成综合网久久久
|
天天躁日日躁狠狠久久
|
久久精品蜜芽亚洲国产AV
|
99久久免费国产精品
|
国产精品成人久久久
|
国产精品久久久久…
|
亚洲另类欧美综合久久图片区
|
久久精品国产清自在天天线
|
青草国产精品久久久久久
|
久久国产免费观看精品
|
亚洲国产成人精品女人久久久
|
久久久国产视频
|
精品国产福利久久久
|
香蕉久久夜色精品国产尤物
|
狠狠色丁香久久婷婷综合_中
|
久久笫一福利免费导航
|
国产成人综合久久精品尤物
|
亚洲午夜无码久久久久小说
|
久久久久人妻精品一区二区三区
|
久久国产成人精品麻豆
|
伊人热热久久原色播放www
|
77777亚洲午夜久久多喷
|
午夜肉伦伦影院久久精品免费看国产一区二区三区
|
久久毛片免费看一区二区三区
|
精品永久久福利一区二区
|
久久经典免费视频
|
热综合一本伊人久久精品
|
一本色道久久综合狠狠躁
|
狠狠色综合网站久久久久久久
|
久久九九精品99国产精品
|
欧美伊人久久大香线蕉综合
|
久久国产精品免费一区
|
中文精品久久久久国产网址
|
久久午夜无码鲁丝片
|
久久精品国产亚洲AV蜜臀色欲
|
亚洲精品国产自在久久
|
久久精品18
|