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

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

    题目概述:

      给你一些句子,统计每个句子中单词的个数。

    大致思路:

      这个题有几种思路,一种是用Tire树,在插入单词过程中如果新建了一个节点便说明这个单词是新单词,需要注意的是有些单词可能是另一些的前缀,这里需要特殊处理一下。

      还有就是STL了,map,set都行,因为我没有用STL就不细说了。

    代码:

     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 10010
    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 struct node
    25 {
    26     bool End;
    27     node *next[26];
    28 } tire;
    29 
    30 bool Insert(node *root,char *s2)
    31 {
    32     node *p=root;int t;
    33     bool ans=false;
    34     while(*s2!='')
    35     {
    36         t=*s2-'a';
    37         if(p->next[t]==NULL)
    38         {
    39             node *temp=(node *)malloc(sizeof(node));
    40             for(int i=0;i<26;i++) temp->next[i]=NULL;
    41             temp->End=false;p->next[t]=temp;ans=true;
    42         }
    43         p=p->next[t];s2++;
    44     }
    45     if(!p->End) ans=true;
    46     p->End=true;
    47     return ans;
    48 }
    49 
    50 void Delete(node *root)
    51 {
    52     for(int i=0;i<26;i++)
    53         if(root->next[i]!=NULL) Delete(root->next[i]);
    54     free(root);
    55 }
    56 
    57 int main()
    58 {
    59     //freopen("data.in","r",stdin);
    60     //freopen("data.out","w",stdout);
    61     //clock_t st=clock();
    62     char s2[maxn];
    63     int cnt;char s;
    64     while(1)
    65     {
    66         node *root=(node *)malloc(sizeof(node));
    67         for(int i=0;i<26;i++) root->next[i]=NULL;
    68         root->End=false;int lenb=0;cnt=0;
    69         while(scanf("%c",&s)!=EOF)
    70         {
    71             if(s=='#') return 0;
    72             if(s=='
    ') break;
    73             if(s<'a'||s>'z')
    74             {
    75                 if(lenb!=0)
    76                 {
    77                     s2[lenb]='';
    78                     if(Insert(root,s2)) cnt++;
    79                     lenb=0;
    80                 }
    81             }
    82             else s2[lenb++]=s;
    83         }
    84         if(lenb!=0)
    85         {
    86             s2[lenb]='';
    87             if(Insert(root,s2)) cnt++;
    88             lenb=0;
    89         }
    90         printf("%d
    ",cnt);
    91         Delete(root);
    92     }
    93     //clock_t ed=clock();
    94     //printf("
    
    Time Used : %.5lf Ms.
    ",(double)(ed-st)/CLOCKS_PER_SEC);
    95     return 0;
    96 }
  • 相关阅读:
    selenium产生的垃圾文件清理
    英语学习词根法
    ecommerce学习
    tfs2012安装
    转载文件,英语学习
    Mishka and Divisors CodeForces
    Codeforces Round #364 (Div. 1) (差一个后缀自动机)
    莫比乌斯反演练习
    bzoj 1267 Kth Number I (点分治,堆)
    程序员的绘图利器 — Gnuplot
  • 原文地址:https://www.cnblogs.com/CtrlKismet/p/6352112.html
Copyright © 2011-2022 走看看