- 浏览: 125209 次
- 性别:
- 来自: 成都
文章分类
最新评论
-
leelege:
让一切GenericDao都去死吧
自己写的一个Hibernate CURD的封装 -
liuxuejin:
不用泛型的飘过,个人觉得没有什么必要,因为增删查的代码(简单的 ...
自己写的一个Hibernate CURD的封装 -
java113096:
finallygo 写道icanfly 写道ricoyu 写道 ...
自己写的一个Hibernate CURD的封装 -
jiluo093:
http://jiluo093.iteye.com/blog/ ...
自己写的一个Hibernate CURD的封装 -
piao_bo_yi:
Dev|il 写道yin_bp 写道Dev|il 写道dnst ...
自己写的一个Hibernate CURD的封装
病毒侵袭
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 2557 Accepted Submission(s): 667
Problem Description
当太阳的光辉逐渐被月亮遮蔽,世界失去了光明,大地迎来最黑暗的时刻。。。。在这样的时刻,人们却异常兴奋——我们能在有生之年看到500年一遇的世界奇观,那是多么幸福的事儿啊~~
但网路上总有那么些网站,开始借着民众的好奇心,打着介绍日食的旗号,大肆传播病毒。小t不幸成为受害者之一。小t如此生气,他决定要把世界上所有带病毒的网站都找出来。当然,谁都知道这是不可能的。小t却执意要完成这不能的任务,他说:“子子孙孙无穷匮也!”(愚公后继有人了)。
万事开头难,小t收集了好多病毒的特征码,又收集了一批诡异网站的源码,他想知道这些网站中哪些是有病毒的,又是带了怎样的病毒呢?顺便还想知道他到底收集了多少带病毒的网站。这时候他却不知道何从下手了。所以想请大家帮帮忙。小t又是个急性子哦,所以解决问题越快越好哦~~
Input
第一行,一个整数N(1<=N<=500),表示病毒特征码的个数。
接下来N行,每行表示一个病毒特征码,特征码字符串长度在20—200之间。
每个病毒都有一个编号,依此为1—N。
不同编号的病毒特征码不会相同。
在这之后一行,有一个整数M(1<=M<=1000),表示网站数。
接下来M行,每行表示一个网站源码,源码字符串长度在7000—10000之间。
每个网站都有一个编号,依此为1—M。
以上字符串中字符都是ASCII码可见字符(不包括回车)。
Output
依次按如下格式输出按网站编号从小到大输出,带病毒的网站编号和包含病毒编号,每行一个含毒网站信息。
web 网站编号: 病毒编号 病毒编号 …
冒号后有一个空格,病毒编号按从小到大排列,两个病毒编号之间用一个空格隔开,如果一个网站包含病毒,病毒数不会超过3个。
最后一行输出统计信息,如下格式
total: 带病毒网站数
冒号后有一个空格。
Sample Input
3
aaa
bbb
ccc
2
aaabbbccc
bbaacc
Sample Output
web 1: 1 2 3
total: 1
用kmp和trie树都超时
kmp代码:
#include <iostream> using namespace std; int next[501][205]; char web[10001][10005]; char code[501][205]; void getNext(char c[], int cns) { int len = strlen(c); int i = 0, j = -1; next[cns][0] = -1; while(i < len) { if(j == -1 || c[i] == c[j]) { i++; j++; if(c[i] == c[j]) next[cns][i] = next[cns][j]; else next[cns][i] = j; }else j = next[cns][j]; } } bool kmp(char w[], char c[], int cns) { int i = 0, j = 0; int wlen = strlen(w), clen = strlen(c); while(i < wlen && j < clen) { if(j == -1 || w[i] == c[j]) { i++; j++; }else j = next[cns][j]; } if(j == clen) return true; return false; } int main() { int n, m, i, j, total; bool flag; while(cin>>n) { for(i = 0; i < n; i++) { cin>>code[i]; getNext(code[i], i); } cin>>m; total = 0; for(i = 0; i < m; i++) { cin>>web[i]; flag = true; for(j = 0; j < n; j++) { if(kmp(web[i], code[j], j)) if(flag) { cout<<"web "<<i + 1<<":"<<" "<<j + 1; total++; flag = false; } else cout<<" "<<j + 1; } if(!flag) cout<<endl; } cout<<"total: "<<total<<endl; } return 0; }
trie树代码:
#include <iostream> using namespace std; const int branch = 100; char code[205]; char web[10005]; bool flag; int total; typedef struct trie_node{ bool isword; bool isMatch; int rank; struct trie_node *next[branch]; trie_node():isword(false), rank(0), isMatch(false) { memset(next, NULL, sizeof(next)); } }*pTrie_Node; class Trie{ private: pTrie_Node root; public: Trie() { root = new trie_node(); } pTrie_Node getRoot() { return root; } void insert(const char *word, int r); void destory(pTrie_Node cur); void search(const char *word, int r); void clear(pTrie_Node cur); }; void Trie::insert(const char *word, int r) { pTrie_Node loc = root; while(*word && loc) { if(loc->next[*word - 31] == NULL) loc->next[*word - 31] = new trie_node(); loc = loc->next[*word - 31]; word++; } loc->isword = true; loc->rank = r; } void Trie::destory(pTrie_Node cur) { for(int i = 0; i < branch; i++) if(cur->next[i] != NULL) destory(cur->next[i]); delete cur; } void Trie::search(const char *word, int r) { pTrie_Node loc = root; while(*word && loc) { loc = loc->next[*word - 31]; if(loc && loc->isword && !loc->isMatch) { if(flag) { cout<<"web "<<r<<":"<<" "<<loc->rank; total++; flag = false; }else cout<<" "<<loc->rank; loc->isMatch = true; } word++; } } void Trie::clear(pTrie_Node cur) { for(int i = 0; i < branch; i++) if(cur->next[i] != NULL) clear(cur->next[i]); if(cur->isword) cur->isMatch = false; } int main() { int n, m, i, j, len; while(cin>>n) { Trie t; for(i = 1; i <= n; i++) { cin>>code; t.insert(code, i); } cin>>m; total = 0; for(i = 1; i <= m; i++) { flag = true; cin>>web; len = strlen(web); for(j = 0; j < len; j++) { t.search(&web[j], i); } t.clear(t.getRoot()); if(!flag) cout<<endl; } cout<<"total: "<<total<<endl; t.destory(t.getRoot()); } return 0; }
发表评论
-
求n个元素集合的子集(幂集)或n个元素的组合
2011-10-21 13:19 3201回溯法是设计递归过程的一种重要方法,它的求解过程是遍历一个状态 ... -
螺旋矩阵
2011-10-19 13:26 1015给一个正整数n,输出一个n*n的螺旋矩阵 螺旋矩阵可以是逆时针 ... -
HDU 2203(亲和串)
2011-09-26 13:10 1081亲和串 Time Limit: 3000/1000 MS (J ... -
HDU2060(Snooker)
2011-09-17 19:20 909Snooker Time Limit: 1000/1000 M ... -
HDU1166(敌兵布阵)
2011-09-17 12:55 856敌兵布阵 Time Limit: 2000/1000 MS ( ... -
HDU1754 I Hate It
2011-09-16 23:40 1060参考资料:http://www.cppblog.com/MiY ... -
HDU1686Oulipo
2011-09-14 22:15 884Oulipo Time Limit: 3000/1000 MS ... -
HDU2100Lovekey
2011-09-12 17:16 728Lovekey Time Limit: 3000/1000 M ... -
HDU3368 Reversi(黑白棋)
2011-09-11 23:04 1069Reversi Time Limit: 5000/2000 M ... -
HDU1010Tempter of the Bone
2011-09-11 23:02 557Tempter of the Bone Time Limit: ... -
求一个集合的全排列
2011-09-11 14:49 818#include <iostream> usin ... -
HDU1175连连看
2011-09-09 23:24 793连连看 Time Limit: 20000/10000 MS ... -
HDU1711Number Sequence
2011-09-09 13:09 742Number Sequence Time Limit: 100 ... -
串的模式匹配算法
2011-09-07 14:01 665c实现 #include <iostream> ... -
HDU1097A hard puzzle
2011-09-06 22:46 858A hard puzzle Time Limit: 2000/ ... -
串的顺序实现
2011-09-06 11:26 846串的顺序实现 串的顺序结构实现有弊端: 1.串的最大长度固定 ... -
HDU1004Let the Balloon Rise
2011-09-06 09:44 536Let the Balloon Rise Time Limit ... -
HDU2061Treasure the new start, freshmen!
2011-08-24 14:06 1013Treasure the new start, freshme ... -
HDU2251Seinfeld
2011-08-24 13:39 897Seinfeld Time Limit: 2000/1000 ... -
HDU2083简易版之最短距离
2011-08-22 15:30 920简易版之最短距离 Time Limit: 1000/1000 ...
相关推荐
HDU(杭州电子科技大学在线评测系统)是一个深受程序员喜爱的在线编程练习平台,它提供了丰富的算法题目供用户挑战,帮助他们提升编程技能和算法理解能力。"hdu.rar_hdu"这个压缩包文件很可能是某位程序员整理的他在...
【标题】"HDU_2010.rar"是一个压缩包文件,其中包含了与"HDU 2010"相关的资源,特别是针对"HDU ACM20"比赛的编程题目。"hdu 2010"和"hdu 20"可能是该比赛的不同简称或分类,而"hdu acm20"可能指的是该赛事的第20届...
【标题】"HDU题目java实现"所涉及的知识点主要集中在使用Java编程语言解决杭州电子科技大学(HDU)在线评测系统中的算法问题。HDU是一个知名的在线编程竞赛平台,它提供了大量的算法题目供参赛者练习和提交解决方案...
ACM HDU 题目分类 ACM HDU 题目分类是指对 HDU 在线判题系统中题目的分类,总结了大约十来个分类。这些分类将有助于编程选手更好地理解和解决问题。 DP 问题 DP(Dynamic Programming,动态规划)是一种非常重要...
### hdu1250高精度加法 #### 背景介绍 在计算机科学与编程竞赛中,处理大整数运算(特别是加法、减法、乘法等)是常见的需求之一。当数字的位数超过了标准数据类型(如`int`、`long`等)所能表示的最大值时,就需要...
【标题】"HDU DP动态规划"涉及到的是在算法领域中的动态规划(Dynamic Programming,简称DP)技术,这是解决复杂问题的一种高效方法,尤其适用于有重叠子问题和最优子结构的问题。动态规划通常用于优化多阶段决策...
HDU1059的代码
hdu1001解题报告
hdu 1574 passed sorce
【标题】"hdu.rar_HDU 1089.cpp_OJ题求和_hdu_horsekw5_杭电obj" 提供的信息是关于一个压缩文件,其中包含了一个名为 "HDU 1089.cpp" 的源代码文件,这个文件是为了解决杭州电子科技大学(Hangzhou Dianzi ...
hdu2101AC代码
【ACM HDU】指的是在ACM(国际大学生程序设计竞赛,International Collegiate Programming Contest)中,参赛者在杭州电子科技大学(Hangzhou Dianzi University,简称HDU)的在线评测系统上完成并已解决的题目集合...
【标题】:杭电ACMhdu1163 【描述】:这是一道源自杭州电子科技大学(Hangzhou Dianzi University,简称HDU)的ACM编程竞赛题目,编号为1163。这类问题通常需要参赛者利用计算机编程解决数学、逻辑或算法上的挑战,...
hdu 5007 Post Robot 字符串枚举。 暴力一下就可以了。
HDU是杭州电子科技大学(Hangzhou Dianzi University)举办的一个在线编程竞赛平台,全称为HDU Online Judge。ACM是国际大学生程序设计竞赛(International Collegiate Programming Contest)的缩写,是一个全球性的...
【ACM入门与提高:HDU ACM竞赛课程详解】 ACM(国际大学生程序设计竞赛,International Collegiate Programming Contest,简称ICPC或ACM/ICPC)是一项全球性的竞赛,旨在激发大学生对计算机科学的兴趣,提升他们的...
hdu 1166线段树代码
HDU(Hangzhou Dianzi University)是国内外知名的在线编程竞赛平台,主要服务于ACM/ICPC(国际大学生程序设计竞赛)以及相关的算法训练。"HDU最全ac代码"这个压缩包很可能是包含了在HDU平台上解题通过的完整源代码...
根据提供的信息,我们可以总结出以下关于“hdu动态规划算法集锦”的知识点: ### 动态规划基础概念 动态规划是一种解决多阶段决策问题的方法,它通过将原问题分解为互相重叠的子问题,利用子问题的解来构建原问题...
Hdu 1237 解题代码