zoukankan      html  css  js  c++  java
  • HDOJ1251解题报告【字典树】

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1251

    题目概述:

      给你一些单词和一些询问,对于每个询问求出所有单词中以询问为前缀的单词个数。

    大致思路:

      稍微修改一下Tire树就好了,对每个节点增加一个标记来记录到这个节点共有几个单词,这个题还需要注意用g++提交指针版的会MLE,所以需要用数组形式的Tire树。

      年轻的我还是被输入给坑了……果然naive.

    代码:

     1 #include <iostream>
     2 #include <cstdio>
     3 #include <cstdlib>
     4 #include <cmath>
     5 #include <vector>
     6 #include <ctime>
     7 #include <map>
     8 #include <queue>
     9 #include <cstring>
    10 #include <algorithm>
    11 using namespace std;
    12 
    13 #define sacnf scanf
    14 #define maxn 1000010
    15 #define inf 1061109567
    16 #define Eps 0.001
    17 #define PI 3.1415927
    18 #define mod 9973
    19 #define MAXNUM 10000
    20 void Swap(int &a,int &b) {int t=a;a=b;b=t;}
    21 int Abs(int x) {return (x<0)?-x:x;}
    22 typedef long long ll;
    23 
    24 int tree[maxn][26];
    25 int cnt[maxn];
    26 int dir=1;
    27 
    28 void Insert(char *s)
    29 {
    30     int p=0,len=strlen(s);
    31     for(int i=0;i<len;i++)
    32     {
    33         if(!tree[p][s[i]-'a'])
    34         {
    35             tree[p][s[i]-'a']=dir;
    36             cnt[dir]++;dir++;
    37         }
    38         else cnt[tree[p][s[i]-'a']]++;
    39         p=tree[p][s[i]-'a'];
    40     }
    41 }
    42 
    43 int query(char *s)
    44 {
    45     int p=0,len=strlen(s);
    46     for(int i=0;i<len;i++)
    47     {
    48         if(tree[p][s[i]-'a']!=0) p=tree[p][s[i]-'a'];
    49         else return 0;
    50     }
    51     return cnt[p];
    52 }
    53 
    54 int main()
    55 {
    56     //freopen("data.in","r",stdin);
    57     //freopen("data.out","w",stdout);
    58     //clock_t st=clock();
    59     char s[20];
    60     memset(cnt,0,sizeof(cnt));
    61     while(gets(s))
    62     {
    63         if(strlen(s)==0) break;
    64         Insert(s);
    65     }
    66     while(gets(s))
    67     {
    68         printf("%d
    ",query(s));
    69     }
    70     //clock_t ed=clock();
    71     //printf("
    
    Time Used : %.5lf Ms.
    ",(double)(ed-st)/CLOCKS_PER_SEC);
    72     return 0;
    73 }
  • 相关阅读:
    [bzoj1064][Noi2008]假面舞会
    [bzoj1503][NOI2004]郁闷的出纳员
    [bzoj1758][Wc2010]重建计划
    [bzoj1588][HNOI2002]营业额统计
    [bzoj2423][HAOI2010]最长公共子序列
    [3.26福建四校联考]
    [51nod1238]最小公倍数之和V3
    [bzoj2301] [HAOI2011]Problem b
    [hdu5608]function
    [51nod1239欧拉函数之和]
  • 原文地址:https://www.cnblogs.com/CtrlKismet/p/6337965.html
Copyright © 2011-2022 走看看