【练习04】 字典树 1001 Hat’s Words
来源:互联网 发布:枪神纪近战武器数据 编辑:程序博客网 时间:2024/06/10 02:19
算法思路:考察数据结构Trie。
在31ms的时候WA了几次,后来发现是search函数的条件判断出了问题,加了一个flag标记之后AC了。
很神奇的是最后也是31msAC的,难道上面的错误只有最后一个测试数据才能发现?还是judge是在所有打印完之后再检查正确性的?
代码如下:
//模板开始#include <string> #include <vector> #include <algorithm> #include <iostream> #include <sstream> #include <fstream> #include <map> #include <set> #include <cstdio> #include <cmath> #include <cstdlib> #include <ctime>#include <iomanip>#include <string.h>#include <queue>#define SZ(x) (int(x.size()))using namespace std;int toInt(string s){istringstream sin(s); int t; sin>>t; return t;}template<class T> string toString(T x){ostringstream sout; sout<<x; return sout.str();}typedef long long int64;int64 toInt64(string s){istringstream sin(s); int64 t; sin>>t;return t;}template<class T> T gcd(T a, T b){ if(a<0) return gcd(-a, b);if(b<0) return gcd(a, -b);return (b == 0)? a : gcd(b, a % b);}//模板结束(通用部分)#define ifs cin#define maxnode 5000000#define maxword 50005#define wordlen 100#define sigma_size 26int count[maxnode];char words[maxword][wordlen];struct Trie{int ch[maxnode][sigma_size];int val[maxnode];int sz;Trie(){sz = 1;memset(ch[0], 0, sizeof(ch[0]));}int idx(char c){return c - 'a';}void insert(char* s, int v){int u = 0, n = strlen(s);for(int i = 0; i < n; i++){int c = idx(s[i]);if(!ch[u][c]){memset(ch[sz], 0, sizeof(ch[sz]));val[sz] = 0;ch[u][c] = sz++;}u = ch[u][c];}val[u] = v;}int search(char* s, int n){int u = 0;int flag = 1;for(int i = 0; i < n; i++){int c = idx(s[i]);if(ch[u][c] == 0){flag = 0;break;}u = ch[u][c];}if(flag && val[u]){return 1;}else{return 0;}}};Trie t;//【练习04】 字典树 1001 Hat’s Wordsint main(){//ifstream ifs("shuju.txt", ios::in);int wordsize = 0;while(ifs>>words[wordsize]){t.insert(words[wordsize], 1);wordsize++;}for(int i = 0; i < wordsize; i++){//cout<<sizeof(words[i])<<endl;int len = strlen(words[i]);//cout<<len<<endl;for(int j = 1; j < len; j++){//cout<<j<<endl;if(t.search(&words[i][0], j) && t.search(&words[i][j], len - j)){cout<<words[i]<<endl;break;}}}return 0;}
- 【练习04】 字典树 1001 Hat’s Words
- Hat’s Words(字典树)
- Hat’s Words(字典树)
- hdu Hat‘s Words(字典树)
- 【字典树】 hdu1247 Hat’s Words
- Hat’s Words hdu1247 字典树+搜索
- HDU 1247 Hat’s Words(字典树)
- hdu 1247 字典树 Hat’s Words
- HDU1247-Hat’s Words(字典树)
- HDU 1247 Hat’s Words 字典树
- Hat’s Words(hdu1247字典树)
- hdu1247 Hat’s Words (字典树)
- hdu 1247 Hat’s Words 字典树
- HDU 1247 Hat’s Words(字典树)
- hdu1247 Hat’s Words(字典树)
- [HDOJ 1247] Hat’s Words [字典树]
- hdu 1247 Hat’s Words(字典树)
- hdu 1247 Hat’s Words字典树
- jquery笔记
- malloc和new的区别
- C语言小程序(六)、数组操作
- 使用eclipse来打jar包
- 第一次参加Coding Dojo(编程道场)有感
- 【练习04】 字典树 1001 Hat’s Words
- Hibernate学习笔记
- 编译 mongoclient.lib
- C++成员初始化列表使用总结
- 利用双缓冲技术将位图像素数据写到DIB位图中并在指定的窗口显示(主要使用CreateDIBSection和BitBlt方法)
- DBGridEh控制单元格显示以及存储过程 触发器和视图以及事务的使用
- Android Fragment初探
- LPCTSTR类型
- VS2010中配置文件的使用