一个很经典的字典树题目 

先建树 再拆单词进行判断是否都在树内

 

因为爆内存错了很久

如果一个四十万的数组  用mamset的话会直接爆几十万的内存  

所以要:用多少 初始化多少才对!( 修改了两条初始化语句 见代码)  不过这题只有一组数据  所以不初始化关系不大

#include<bits/stdc++.h>
using namespace std;

int  trie[400100][26]={0};
int  sum[400100];
char ans[50005][30];//这里数组开小了导致一直wa
int root=0;
int pos=1;
void insert1(char *s)
{
    int root=0;
    for(int i=0;i<strlen(s);i++)
    {   int ch=s[i]-'a';
        if( trie[ root ][ch]==0  )
          {

             memset(trie[pos],0,sizeof(trie[pos]));//用多少初始化多少
             trie[root][ch]=pos++;

          }
        root=trie[root][ch];
    }
    sum[root]=1;
}

bool  find1(char *s)
{
    int root=0;
    for(int i=0;i<strlen(s);i++)
    {
        int ch=s[i]-'a';
        if( trie[root][ch]==0 )return false;
        root=trie[root][ch];

    }
    return sum[root];

}

int main()
{


   int c=0;
   pos=1;
   memset(sum,0,sizeof(sum));
    memset(trie[0],0,sizeof(trie[0]));//用多少初始化多少
    while(gets(ans[c++]))
    {
     insert1( ans[c-1] );
    }

    for(int i=0;i<=c-1;i++)
    {

        for(int k=1;k<strlen( ans[i] ) ;k++)
        {
            char a[30],b[30];
            strncpy(a,ans[i],k   );a[k]='\0';
            strncpy(b,ans[i]+k, strlen(ans[i]) );
            b[strlen(ans[i]) -k]='\0';
            if(find1(b)&&find1(a))
            {
                puts(ans[i]);break;

            }
        }

    }

return 0;
}