Реализация попыток и суффиксовых деревьев - PullRequest
4 голосов
/ 22 июля 2010

Я изучил деревья Трис и Суффикс и хотел реализовать то же самое. Пожалуйста, поделитесь некоторыми ссылками, где я могу получить представление о структуре и основной идее реализации, с которой можно начать.

Любой хороший пример, если он будет включен, будет плюсом.

Реализация в кл.

Ответы [ 4 ]

8 голосов
/ 22 июля 2010

Библиотека алгоритмов C (http://fragglet.github.io/c-algorithms/) предлагает реализацию Trie в C . Это открытый исходный код с лицензией в стиле BSD.

Реализация суффиксного дерева в C может быть найдена здесь: https://github.com/0xtonyxia/suffix-tree

Надеюсь, это поможет.

3 голосов
/ 31 августа 2012
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<string.h>

typedef struct trie trie;
struct trie
{
       char key;
       trie *next,*children;
};

trie *newnode(char s)
{
     trie *t=(trie *)malloc(sizeof(trie));
     t->key=s;
     t->next=t->children=NULL;
}

void insert(trie **t,char *s,int start)
{if(s[start]=='\0')
                   {
                          *t=newnode('#');
                          return;
                   } 
                   if(*t==NULL)
                   {
                               *t=newnode(s[start]);
                               insert(&(*t)->children,s,start+1);
                   }       
                   if((*t)->key==s[start])
                   insert(&(*t)->children,s,start+1);
                   else
                   insert(&(*t)->next,s,start);
}


bool search(trie *t ,char *s,int start)
{


     if(t==NULL)
     return false;

     if(t->key=='#' && s[start]=='\0')
     return true;

     if(t->key!='#' && s[start]=='\0' || t->key=='#' && s[start]!='\0')
     return false;

     if(t->key==s[start])
     return search(t->children,s,start+1);

     else
     return search(t->next,s,start);

     return false;
}

/*void push(trie **t ,char *str)
{                        int i=0;
                         for(i=0;i<strlen(str);i++)
                         insert(t,str[i]);
}*/

main()
{     int i=0;

      trie *t=NULL;
      char ch='y';
      while(ch=='y')
      {             
                    {char str[20];
                    fflush(stdin);
                    printf("Enter the word ");
                    gets(str);


                    insert(&t,str,0);
                    }
                   // push(&t,str);
                    fflush(stdin);
                    printf("more y/n ::");
                    ch=getchar();
      }

      ch='y';
      while(ch=='y')
      {char str[20];
      fflush(stdin);
      printf("Enter the string you want to search::");
      gets(str);

      fflush(stdin);
      if(search(t,str,0))
      printf("Found");
      else
      printf("Not Found");

      printf("\n more y/n ::");
      scanf("%c",&ch);

      }

    getch();  

}
0 голосов
/ 16 марта 2015
#include <iostream>
#include <string.h>
using namespace std;
int high;
struct stnode
{
    stnode* ptr[27];
    int start;
    int end;
    stnode(int s,int e)
    {
        for (int i = 0; i < 27; ++i)
        {
            ptr[i]=NULL;
        }
        start=s;
        end=e;
    }
}*root=NULL;


stnode* fun(stnode* child,string str,int ind)
{
    int s=child->start;
    while(s<=child->end&&str.at(s)==str.at(ind))
        {
            s++;
            ind++;
        }
    if(s<=child->end)
    {
        child->ptr[str.at(ind)-'a']=new stnode(ind,high);
        if(str.at(s)=='$')
            child->ptr[26]=new stnode(s,child->end);
        else
            child->ptr[str.at(s)-'a']=new stnode(s,child->end);
        child->end=s-1;
        return child;
    }
    else
    {
        if(child->ptr[str.at(ind)-'a'])
        {
            child->ptr[str.at(ind)-'a']=fun(child->ptr[str.at(ind)-'a'],str,ind);
            return child;
        }
        else
        {
            child->ptr[str.at(ind)-'a']=new stnode(ind,high);
            return child;
        }
    }

}



stnode* create(stnode* root,string str,int ind)
{
    if(!root)
    {
        root=new stnode(ind,high);
        return root;
    }
    if(str.at(ind)=='$')
    {
        root->ptr[26]=new stnode(ind,high);
        return root;
    }
    if(!root->ptr[str.at(ind)-'a'])
    {
        root->ptr[str.at(ind)-'a']=new stnode(ind,high);
        return root;
    }
    root->ptr[str.at(ind)-'a']=fun(root->ptr[str.at(ind)-'a'],str,ind);
    return root;
}



void display(stnode* root,string str)
{
    if(!root)
        return;
    if(root->start!=-1)
    {
        for(int i=root->start;i<=root->end;i++)
        {
            cout<<str.at(i);
        }
        cout<<"\n";
    }
    for(int i=0;i<27;i++)
    {
        display(root->ptr[i],str);
    }
}


int main(int argc, char const *argv[])
{
    string str;
    cout<<"enter the string.\n";
    cin>>str;
    str=str+"$";
    high=str.length()-1;

    root=new stnode(-1,-1);

    for(int i=str.length()-1;i>=0;i--)
    {
        root=create(root,str,i);
        display(root,str);
        cout<<"\n\n\n";
    }

    return 0;
}
0 голосов
/ 07 декабря 2014

Вот ссылки, которые я считаю очень полезными.

6-часовая лекция по деревьям суффиксов (Лекция 3 - Лекция 5) Google SCICOMP Лекция 5 (Самая длинная общая проблема с подстрокой: O (n) дерево суффиксов, суффиксы сортировки)

Реализация обобщенного суффиксного дерева http://www.geeksforgeeks.org/generalized-suffix-tree-1/

Быстрый поиск строк с суффиксным деревом http://marknelson.us/1996/08/01/suffix-trees/

Посмотрите алгоритм Укконена в Википедии.Примечание: не может опубликовать более 2 ссылок, потому что не хватает репутации.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...