学习心得(code)

superlong@CoreCoder

  C++博客 :: 首页 :: 联系 :: 聚合  :: 管理
  74 Posts :: 0 Stories :: 5 Comments :: 0 Trackbacks

公告

文字可能放在http://blog.csdn.net/superlong100,此处存放代码

常用链接

留言簿(4)

我参与的团队

搜索

  •  

最新随笔

最新评论

  • 1. re: Poj 1279
  • 对于一个凹多边形用叉积计算面积 后能根据结果的正负来判断给的点集的时针方向?
  • --bsshanghai
  • 2. re: Poj 3691
  • 你写的这个get_fail() 好像并是真正的get_fail,也是说fail指向的串并不是当前结点的子串。为什么要这样弄呢?
  • --acmer1183
  • 3. re: HDU2295[未登录]
  • 这个是IDA* 也就是迭代加深@ylfdrib
  • --superlong
  • 4. re: HDU2295
  • 评论内容较长,点击标题查看
  • --ylfdrib
  • 5. re: HOJ 11482
  • 呵呵..把代码发在这里很不错..以后我也试试...百度的编辑器太烂了....
  • --csuft1

阅读排行榜

评论排行榜

#include <stdio.h>

struct tree
{
    tree 
*fail, *next[2];
    
int flag, visit;
};

tree arr[
30005];
int  indexx;
tree 
*root, *p;

void newn()
{
    arr[indexx].fail 
= NULL;
    arr[indexx].flag 
= 0;
    arr[indexx].visit 
= 0;
    
for(int i = 0; i < 2; i ++) arr[indexx].next[i] = 0;
}

void init()
{
    indexx 
= 0;
    newn();
    root 
= &arr[indexx ++];
}

void insert(char ch[])
{
    
int t, i = 0;
    p 
= root;
    
while(ch[i])
    {
        t 
= ch[i] - '0';
        
if(p->next[t] == 0)
        {
            newn();
            p
->next[t] = &arr[indexx ++];
        }
        p 
= p->next[t];
        i 
++;
    }
    p
->flag = 1;
}

tree 
*que[30005];

bool check(tree *q)
{
    
while(q != root)
    {
        
if(q->flag) return true;
        q 
= q->fail;
    }
    
return false;
}

void get_fail()
{
    
int close = -1, open = 0;
    p 
= root; p->fail = root;
    que[
0= p;
    
while(close < open)
    {
        p 
= que[++close];
        
for(int i = 0; i < 2; i ++)
        {
            
int danger;
            
if(danger = check(p)) p->flag = 1;
            
if(p->next[i] == 0)
            {
                
if(p == root) p->next[i] = root;
                
else          p->next[i] = p->fail->next[i];
            }
            
else
            {
                
if(p == root) p->next[i]->fail = root;
                
else          p->next[i]->fail = p->fail->next[i];
                que[
++open] = p->next[i];
            }
        }
    }
}

int  n;
char str[30005];
bool ok;

void solve(tree *q)
{
    
for(int i = 0; i < 2; i ++)
    {
        
if(q->next[i]->visit)
        {
            ok 
= true
            
return;
        }
        
if(q->next[i]->flag) continue;
        q
->next[i]->flag = 1;
        q
->next[i]->visit = 1;
        solve(q
->next[i]);
        
if(ok) return;
        q
->next[i]->visit = 0;
    }
}

int main()
{
    
while(scanf("%d",&n) != EOF)
    {
        init();
        
for(int i = 0; i < n; i ++
        {
            scanf(
"%s", str);
            insert(str);
        }
        get_fail();
        root
->visit = true;
        ok 
= false;
        solve(root);
        
if(ok)     puts("TAK");
        
else    puts("NIE");
    }
    
return 0;
}

posted on 2009-09-11 14:07 superlong 阅读(190) 评论(0)  编辑 收藏 引用

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理