本文整理汇总了C++中trie类的典型用法代码示例。如果您正苦于以下问题:C++ trie类的具体用法?C++ trie怎么用?C++ trie使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了trie类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: check
bool check(trie<char> &t, string s, int steps, int digits){
// cerr << s << endl;
if (steps < digits) return false;
if (steps == 0) return (bool)t.countMatches(s.begin(), s.end());
if (t.countMatches(s.begin(), s.end())) return true;
if (digits){
for (int i=0;i<s.size();i++){
if (isdigit(s[i])){
for (s[i] = 'a'; s[i] <= 'z'; s[i]++){
if (check(t, s, steps-1, digits-1)) return true;
}
for (s[i] = 'A'; s[i] <= 'Z'; s[i]++){
if (check(t, s, steps-1, digits-1)) return true;
}
}
}
}
else {
for (int i=0; i<s.size()-1; i++){
swap(s[i], s[i+1]);
if (check(t, s, steps-1, digits)) return true;
swap(s[i], s[i+1]);
}
}
return false;
}
示例2: makeTrie
void makeTrie(void) {
map<int, hostConf>::iterator j;
string::iterator stringit;
char* temp = new char[16];
string prestring;
char* size = new char[2];
struct cidrprefix tempFix;
for(j = routerEnd.begin(); j != routerEnd.end(); j++) {
prestring = (j->second).overlayPrefix;
for(stringit = prestring.begin(); stringit != prestring.end(); stringit++) {
if(*stringit == '/') {
strcpy(temp, prestring.substr(0, distance(prestring.begin(),stringit)).c_str());
cout << "Temp: " << temp << endl;
inet_pton(AF_INET, temp, (void *)&tempFix.prefix);
stringit++;
size[0] = *stringit;
stringit++;
size[1] = *stringit;
break;
}
}
tempFix.size = (char)atoi(size);
#ifdef DEBUG
cout << "Prefix: " << tempFix.prefix << "/" << (int)tempFix.size << " for router: " << routerIPs[j->first] << endl;
#endif
hosts.insert(tempFix, routerIPs[j->first]);
#ifdef DEBUG
cout << "Testing trie." << endl;
int testaddr;
inet_pton(AF_INET, "1.2.3.1", (void *)&testaddr);
cout << testaddr << hosts.search(testaddr) << endl;
#endif
}
}
示例3: main
/**
* Conducts behavior described in "Find Strings" problem
*/
int main (){
int n,q;
cin >> n; //get n
if((n < 1) || (n > 50)){
cout << "INVALID"; //1<=n<=50
return 0;
}
string mystr;
for(int i = 0; i < n; i++){
cin >> mystr; //get string
if((mystr.length() > 2000) || (mystr.length() < 1)){
cout << "INVALID"; //1<=mi<=2000
return 0;
}
else{
trie.insert(mystr);
}
}
trie.print();
trie.enum_substrings(substrings);
sort(substrings.begin(), substrings.end());
it = unique(substrings.begin(), substrings.end());
substrings.resize(it - substrings.begin());
print_elements(substrings);
cin >> q; //get q
if((q < 1) || (q > 500)){
cout << "INVALID"; //1<=q<=500
return 0;
}
else{
int myk;
for(int i = 0; i < q; i++){
cin >> myk; //get substring index
if(myk > substrings.size() || ((myk > 1000000000) || (myk < 1))){
kstrings.push_back("INVALID"); //1<=k<=1000000000
}
else{
kstrings.push_back(substrings[myk - 1]);
}
}
print_elements(kstrings);
}
return 0;
}
示例4: operator
void operator()(trie<suffix_payload> & t) {
t.payload.is_orig = false;
t.payload.is_rev = false;
if (t.ch == END1) {
t.payload.is_orig = true;
return;
}
if (t.ch == END2) {
t.payload.is_rev = true;
return;
}
for (auto i = t.children.begin(); i != t.children.end(); ++i) {
if (i->second.payload.is_orig) {
t.payload.is_orig = true;
}
if (i->second.payload.is_rev) {
t.payload.is_rev = true;
}
}
if (t.payload.is_orig && t.payload.is_rev) {
if (t.payload.depth > 1) {
cout << t.path() << endl;
}
}
}
示例5: total_size
/// \brief Returns size and total sum of symbols
template <typename T> std::pair<size_t, size_t> total_size(trie<T> const & t) {
size_t count = 0;
size_t total_count = 0;
t.for_each([&count, &total_count](std::vector<T> const & w) {
++count;
total_count += w.size();
});
return {count, total_count};
}
示例6: main
int main()
{
freopen ("input.txt", "r", stdin);
scanf ("%d", &n); getchar();
bool new_sentence = false;
while(n--)
{
char c = 0;
do
{
c = getchar();
if (c == EOF)
break;
else if (!isalnum(c) && new_sentence)
continue;
else if (c == '?')
{
new_sentence = true;
//flush
printf ("SHIT:\n");
for (int i = 0; i < shit.size(); i++)
putchar (shit[i]); putchar('\n');
sentence_count += _trie.flush();
shit.clear();
}
else if (c == '.' || c == '!')
{
new_sentence = true;
}
else if (c != '\n')
{
shit.push_back(c);
}
} while (c != '\n');
if (c == EOF)
break;
}
printf ("sentence_count: %d\n", sentence_count);
return 0;
}
示例7: find
void find(string &str, int pos, int bitm, ll lvl = 0){
bitmask |= bitm;
if(bitmask == finalbit){
res = max(res, lvl);
}
if(pos == str.length() or lvl > 60){
return;
}
if(str[pos] == 'a'){
if(a == NULL){
a = new trie;
}
a->find(str, pos + 1, bitm, lvl + 1);
} else {
if(b == NULL){
b = new trie;
}
b->find(str, pos + 1, bitm, lvl + 1);
}
}
示例8: flatten
/// \brief Flattens a trie \p t
/// \returns an array of words (without the prefixes)
template <typename T> std::vector<std::vector<T>> flatten(trie<T> const & t) {
std::vector<std::vector<T>> ret;
t.for_each([&ret](std::vector<T> const & w) { ret.push_back(w); });
return ret;
}
示例9: main
int main()
{
cout<<"KOAKSODKASdokasdo\n";
_trie = trie();
for (int i = 0; i < 500100; i++)
finished [i] = turns_into [i] = -1;
scanf ("%d", &n); getchar();
for (int i = 0; i < n; i++)
_trie.parse_input();
for (int i = 0; i < words.size(); i++)
printf ("%d ", words [i]); printf ("\n");
scanf ("%d", &m); getchar();
for (int i = 0; i < m; i++)
{
int X = _trie.parse_input();
int Y = _trie.parse_input();
printf ("%d %d\n", X, Y);
turns_into[X] = Y;
cool [X] = true;
QMAX = max (X, Y);
}
QMAX = max (QMAX, word_index);
int R = 0, L = 0;
for (int i = 0; i < words.size(); i)
{
if (turns_into [words [i]] == -1)
{
R += R_count [words [i]];
L += lengths [words [i]];
}
else if (finished [words [i]])
{
R += R_count [words [i]];
L += lengths [words [i]];
}
else
{
stacks.clear();
int current_index = words [i];
int q = i - 1;
while (finished [current_index] != -1)
{
stacks.push_back(current_index);
finished[current_index] = 1;
current_index = turns_into [current_index];
}
stacks.push_back(current_index);
int MAXR = R_count[current_index];
int MAXL = lengths[current_index];
for (int j = stacks.size() - 2; j > -1; j--)
{
if (R_count [stacks [j]] == R_count [stacks [j - 1]])
{
R_count[stacks [j]] = R_count[stacks [j + 1]];
}
}
}
}
return 0;
}
示例10: WordFilter
WordFilter(vector<string> words) {
for (int i = 0; i < words.size(); i++) {
t_prefix.insert(words[i], i);
reverse(words[i].begin(), words[i].end());
t_suffix.insert(words[i], i);
}
}
示例11: generate
void generate(string s, int val)
{
queue<string> q;
int i, h, pai, filho;
if(m.count(s) == 0)
{
m[s] = m.size() - 1;
q.push(s);
}
pai = m[s];
tam[pai] = val;
while(!q.empty())
{
s = q.front();
pai = m[s];
q.pop();
if(tam[pai] > resp) continue;
query.clear();
t.match(s, 0);
for(i=0;i<query.size();i++)
{
if(!sufix(s, query[i])) continue;
if(m.count(sufstr) == 0)
{
m[sufstr] = m.size() - 1;
filho = m.size() - 1;
q.push(sufstr);
}
else filho = m[sufstr];
tam[filho] = tam[pai] + sufdis;
grafo[pai].push_back(filho);
peso[pai].push_back(sufdis);
}
}
}
示例12: AutocompleteSystem
AutocompleteSystem(vector<string> sentences, vector<int> times) {
for (int i = 0; i < sentences.size(); i++) {
for (int j = 0; j < times[i]; j++)
tr.insert(sentences[i]);
}
node = &tr;
}
示例13: main
int main()
{
while (true)
{
scanf("%d%d",&n,&m);
if (n == 0 && m == 0) break;
ac.init();
for (int i = 0; i < n; i++)
{
scanf("%s",buf);
ac.insert(buf,i);
}
for (int i = 0; i < m; i++)
{
scanf("%s",buf);
ac.insert(buf,-1);
}
ac.build();
tot = 0;
pos[tot++] = 0;
for (int i = 0; i < ac.L; i++)
if (ac.endv[i] == false && ac.endr[i] != 0)
pos[tot++] = i;
for (int i = 0; i < tot; i++)
Gao(i);
memset(dp,-1,sizeof(dp));
dp[0][0] = 0;
for (int i = 0; i < (1<<n); i++)
for (int j = 0; j < tot; j++)
if (dp[i][j] != -1)
for (int k = 0; k < tot; k++)
if (d[j][k] != -1)
{
int newsta = i|ac.endr[pos[k]];
if (dp[newsta][k] == -1 || dp[newsta][k] > dp[i][j]+d[j][k])
dp[newsta][k] = dp[i][j]+d[j][k];
}
int res = -1;
for (int i = 0; i < tot; i++)
if (dp[(1<<n)-1][i] != -1)
if (res == -1 || res > dp[(1<<n)-1][i])
res = dp[(1<<n)-1][i];
printf("%d\n",res);
}
return 0;
}
示例14: main
int main()
{
int N, i, j, k;
vector<string> init;
vector<int> start;
string str;
char s[100];
while(scanf("%d", &N) != EOF && N)
{
v.clear();
init.clear();
start.clear();
t.children.clear();
for(i=0;i<m.size();i++)
{
grafo[i].clear();
peso[i].clear();
tam[i] = INF;
}
m.clear();
m[""] = 0;
for(i=0;i<N;i++)
{
scanf("%s", s);
t.insert(s, 0);
v.push_back(s);
}
for(i=0;i<v.size();i++)
{
query.clear();
t.match(v[i], 0);
for(j=0;j<query.size();j++) if(query[j] != v[i])
{
if(!sufix(v[i], query[j])) continue;
init.push_back(sufstr);
start.push_back(max(v[i].size(), query[j].size()));
}
}
resp = INF;
for(i=0;i<init.size();i++) if(start[i] < resp) resp = min(resp, shortest_path(init[i], start[i]));
if(resp == INF) printf("-1\n");
else printf("%d\n", resp);
}
return 0;
}
示例15: input
vector<string> input(char c) {
vector<string> r;
if (c == '#') {
tr.insert(s);
s.clear();
node = &tr;
return r;
}
s.push_back(c);
if (node != nullptr) {
node = node->get_next(c);
if (node != nullptr)
return node->get_top3();
}
return r;
}