trie 的应用

xuzuning 2012-09-21 07:01:58
加精
应 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");
return $this->buffer;
}

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

}
}
...全文
2863 62 打赏 收藏 转发到动态 举报
写回复
用AI写文章
62 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq2305037716 2013-12-02
  • 打赏
  • 举报
回复
学习了,嘿嘿,挺好
anydy2008 2013-08-05
  • 打赏
  • 举报
回复
版主 想请教一下 $TTrie = new TTrie(); $TTrie->set('abc'); $TTrie->set('abd'); var_dump($TTrie->dict); array(5) { [0]=> array(1) { ["a"]=> int(1) } [1]=> array(1) { ["b"]=> int(2) } [2]=> array(2) { ["c"]=> int(3) ["d"]=> int(4) } [3]=> array(1) { ["acc"]=> string(0) "" } [4]=> array(1) { ["acc"]=> string(0) "" } } 那个acc有什么用的呢 是不是各自和c、d 同级才对的呢。
yi890410 2012-11-21
  • 打赏
  • 举报
回复
没看懂 唉 真悲催
  • 打赏
  • 举报
回复
原来这里送分了
oAnJing1234 2012-09-29
  • 打赏
  • 举报
回复
跟着大牛走
皓月长空 2012-09-28
  • 打赏
  • 举报
回复
学习下ing。。。
hahaliu005 2012-09-28
  • 打赏
  • 举报
回复
先顶再看.
loveifa 2012-09-28
  • 打赏
  • 举报
回复
看不懂 帮顶下
ewili 2012-09-28
  • 打赏
  • 举报
回复
这是发月饼吗?
csdn_风中雪狼 2012-09-28
  • 打赏
  • 举报
回复
学习ing
DreamXzn 2012-09-27
  • 打赏
  • 举报
回复
学习下
dic_008 2012-09-27
  • 打赏
  • 举报
回复
visazh 2012-09-26
  • 打赏
  • 举报
回复
weidejif zhihao huitiel
  • 打赏
  • 举报
回复
恭喜,恭喜,来接接分啦!
cainiaophper 2012-09-25
  • 打赏
  • 举报
回复
kan kan
木目子 2012-09-25
  • 打赏
  • 举报
回复
持续接分ing
haoxuexi123456 2012-09-25
  • 打赏
  • 举报
回复
怎么用啊。看不懂。楼主能举几个例子看看吗
bing15 2012-09-25
  • 打赏
  • 举报
回复
中秋来接分了
www_7di_net 2012-09-24
  • 打赏
  • 举报
回复
严重支持这种分享精神,有分享才会有进步
findee 2012-09-24
  • 打赏
  • 举报
回复
接月饼分, 学习, 收藏之
加载更多回复(28)

21,886

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧