首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > PHP >

trie 的运用

2012-12-25 
trie 的应用应 CSDN 要求,收到 CSDN 月饼的应发散分贴前贴已发,由于僧多粥少。故此结贴,比继续发帖散分clas

trie 的应用
应 CSDN 要求,收到 CSDN 月饼的应发散分贴
前贴已发,由于僧多粥少。故此结贴,比继续发帖散分

class TTrie {
  protected $buffer = array();
  protected $dict = array( array() );
  protected $input = 0; //字符串当前偏移
  protected $backtracking = 0; //字符串回溯位置
  public $debug = 0;
  public $savematch = 1;

  function set($word, $action='') {
if(is_array($word)) {
foreach($word as $k=>$v) $this->set($k, $v);
return;
}
$p = count($this->dict);
$cur = 0; //当前节点号
foreach(str_split($word) as $c) {
if (isset($this->dict[$cur][$c])) { //已存在就下移
$cur = $this->dict[$cur][$c];
continue;
}
$this->dict[$p]= array(); //创建新节点
$this->dict[$cur][$c] = $p; //在父节点记录子节点号
$cur = $p; //把当前节点设为新插入的
$p++;
}
$this->dict[$cur]['acc'] = $action; //一个词结束,标记叶子节点
  }

  function match($s) {
$ret = array();
$cur = 0; //当前节点,初始为根节点
$i =& $this->input; //字符串当前偏移
$p =& $this->backtracking; //字符串回溯位置
$s .= "\0"; //附加结束符
$len = strlen($s);
$buf = '';
while($i < $len) {
$c = $s{$i};
if(isset($this->dict[$cur][$c])) { //如果存在
$cur = $this->dict[$cur][$c]; //转到对应的位置
if(isset($this->dict[$cur][$s[$i+1]])) {//检查下一个字符是否也能匹配,长度优先
$i++;
continue;
}
if(isset($this->dict[$cur]['acc'])) { //是叶子节点,单词匹配!
if($buf != '') {
$this->buffer[] = $buf;
$buf = '';
}
if($this->savematch) $this->buffer[] = substr($s, $p, $i - $p + 1); //取出匹配位置和匹配的词

$ar = explode(',', $this->dict[$cur]['acc']);
call_user_func_array( array($this, array_shift($ar)), $ar );

$p = $i + 1; //设置下一个回溯位置
$cur = 0; //重置当前节点为根节点
}
} else { //不匹配
$buf .= $s{$p}; //substr($s, $p, $i - $p + 1); //保存未匹配位置和未匹配的内容
$cur = 0; //重置当前节点为根节点
$i = $p; //把当前偏移设为回溯位置
$p = $i + 1; //设置下一个回溯位置
}
$i++; //下一个字符
}
if(trim($buf, "\0")) $this->buffer[] = trim($buf, "\0");
  }

  function __call($method, $param) {
if($this->debug) printf("偏移:%d 回溯:%d\n", $this->input, $this->backtracking);

  }
}

[最优解释]
引用:
这代码干什么用的?没看懂……
看维基的解释,居然还是不懂…… http://zh.wikipedia.org/wiki/Trie
大学白读了……

字典树,先读入文本(多个字符串),然后查找一个串在文本中出现过几次等相关应用。。。
复杂度就等于这个串的长度。。。。。
优点: 速度快
缺点: 空间花销大
[其他解释]
引用:
字典树,先读入文本(多个字符串),然后查找一个串在文本中出现过几次等相关应用。。。
复杂度就等于这个串的长度。。。。。
优点: 速度快
缺点: 空间花销大

多谢了,现在有点明白了,做个模型,实战理解去了。


[其他解释]
严重支持这种分享精神,有分享才会有进步
[其他解释]
这个是国庆中秋过节的福利么。。。 
[其他解释]


老大在各应我没发散分帖啊?哈哈 ...话说我早发到水区去了.嘿嘿
继续接分
[其他解释]
初学绝对很有用
[其他解释]
初学绝对很有用
[其他解释]

引用:
这代码干什么用的?没看懂……
看维基的解释,居然还是不懂…… http://zh.wikipedia.org/wiki/Trie
大学白读了……


我记得是离散或者编译原理的内容啊
[其他解释]
接分~~~~
是哪家的月饼啊
[其他解释]
我看不到懂样
[其他解释]
这代码干什么用的?没看懂……
看维基的解释,居然还是不懂…… http://zh.wikipedia.org/wiki/Trie
大学白读了……
[其他解释]
没学过算法,看到树就知道爬

文……
[其他解释]
感谢谢
[其他解释]
EWN 
[其他解释]
收藏!
[其他解释]
收藏了嘿嘿
[其他解释]
火钳刘明
[其他解释]
接分,老大威武!
[其他解释]
徐哥谢谢
[其他解释]
谢谢徐哥
[其他解释]
接月饼分, 学习, 收藏之
[其他解释]
很久没来了,以来就看到散分帖,果断接之
[其他解释]
果断回帖来接分!
[其他解释]
接分,mark下,慢慢看
[其他解释]
果断接分 月饼拿来 
[其他解释]
算法贴……感觉c++写的要好看呢……
[其他解释]
好东西呀
[其他解释]
楼主好人啊,谢谢
[其他解释]
我的沙发贴子为什么给删除了,而且也没通知?黑暗?
[其他解释]
收到!接分
[其他解释]
持续接分ing
[其他解释]
怎么用啊。看不懂。楼主能举几个例子看看吗 
[其他解释]
中秋来接分了
[其他解释]
恭喜,恭喜,来接接分啦!
------其他解决方案--------------------


kan kan
[其他解释]
学习下ing。。。
[其他解释]
学习下
[其他解释]
weidejif zhihao huitiel
[其他解释]
先顶再看.
[其他解释]
看不懂 帮顶下

[其他解释]
这是发月饼吗?
[其他解释]
学习ing
[其他解释]
没看懂



真悲催
[其他解释]
原来这里送分了
[其他解释]
跟着大牛走
[其他解释]
该回复于2012-09-22 11:35:43被版主删除
[其他解释]
该回复于2012-09-22 10:38:06被版主删除
[其他解释]
该回复于2012-09-22 12:35:54被版主删除
[其他解释]
该回复于2012-09-22 12:35:06被版主删除
[其他解释]
该回复于2012-09-24 11:16:41被版主删除
[其他解释]
该回复于2012-09-24 08:41:13被版主删除
[其他解释]
该回复于2012-09-24 08:36:22被版主删除
[其他解释]
该回复于2012-09-24 14:26:50被版主删除
[其他解释]
该回复于2012-09-24 17:14:11被版主删除
[其他解释]
该回复于2012-09-24 16:26:24被版主删除
[其他解释]
该回复于2012-09-25 10:40:16被版主删除
[其他解释]
该回复于2012-09-25 09:37:29被版主删除
[其他解释]
该回复于2012-09-26 08:28:36被版主删除
[其他解释]
该回复于2012-09-27 14:06:55被版主删除
[其他解释]
null

热点排行