Trie树,又称字符查找树、前缀树,主要用于字符匹配(详见http://en.wikipedia.org/wiki/Trie)。适合做关键词查找,比如查找文章中的关键字然后给他们加链接。 当然对脏词的过滤应用也是样,只是把替换连接的工作换成了替换字符。

当前的代码还只是进行简单的替换,并没有做一些字符的处理,比如“昨天见到你妈,逼我要买房”,这本身不是脏词,因为有逗号,所以程序里要增加字符的范围判断。

程序中的skip就是用来过滤脏词的简单变体,比如“找*小*姐”,默认是最多跳过3个字符,这个可以随便调整了。总之是一个Trie的锻炼吧。

  1. public class TrieTree
  2. {
  3. private readonly Dictionary<char, TrieTree> Children;
  4. public bool End { get; set; }
  5. public TrieTree()
  6. {
  7. Children = new Dictionary<char, TrieTree>();
  8. }
  9. public void AddKey(string keyword)
  10. {
  11. if (String.IsNullOrEmpty(keyword))
  12. {
  13. return;
  14. }
  15. var cNode = this;
  16. foreach (var key in keyword)
  17. {
  18. if (cNode.Children.ContainsKey(key))
  19. {
  20. cNode = cNode.Children[key];
  21. }
  22. else
  23. {
  24. var node = new TrieTree();
  25. cNode.Children.Add(key, node);
  26. cNode = node;
  27. }
  28. }
  29. cNode.End = true;
  30. }
  31. public void Replace(ref string text)
  32. {
  33. for (var i = 0; i < text.Length; i++)
  34. {
  35. var cNode = this;
  36. var key = text[i];
  37. //碰到脏词的第一个词
  38. if (cNode.Children.ContainsKey(key))
  39. {
  40. cNode = cNode.Children[key];
  41. //查找是否包含脏词后面的词
  42. var skip = 0;
  43. for (var j = i + 1; j < text.Length; j++)
  44. {
  45. if (cNode.Children.ContainsKey(text[j]))
  46. {
  47. cNode = cNode.Children[text[j]];
  48. skip = 0;
  49. }
  50. else
  51. {
  52. //允许略过过几个字符
  53. skip++;
  54. if (skip > 3)
  55. {
  56. break;
  57. }
  58. }
  59. if (cNode.End)
  60. {
  61. var len = j + 1 - i;
  62. text = text.Replace(text.Substring(i, len), string.Empty.PadLeft(len, '*'));
  63. i += len;
  64. break;
  65. }
  66. }
  67. }
  68. }
  69. }
  70. }

使用方法如下:

  1. class Program
  2. {
  3. static void Main(string[] args)
  4. {
  5. var trie = new TrieTree();
  6. var keywords = "我操,妓女,fuck".Split(',');
  7. foreach (var key in keywords)
  8. {
  9. trie.AddKey(key);
  10. }
  11. var text = @"我擦啊,尼玛,,fuck you,你这个妓女,贱人。";
  12. trie.Replace(ref text);
  13. Console.WriteLine(text);
  14. Console.Read();
  15. }
  16. }

执行的结果:

转自http://blog.csdn.net/maddemon/article/details/7011699

Trie树-脏词过滤应用的更多相关文章

  1. 转,敏感词过滤,PHP实现的Trie树

    原文地址:http://blog.11034.org/2012-07/trie_in_php.html 项目需求,要做敏感词过滤,对于敏感词本身就是一个CRUD的模块很简单,比较麻烦的就是对各种输入的 ...

  2. [转载]敏感词过滤,PHP实现的Trie树

    原文地址:http://blog.11034.org/2012-07/trie_in_php.html 项目需求,要做敏感词过滤,对于敏感词本身就是一个CRUD的模块很简单,比较麻烦的就是对各种输入的 ...

  3. [原创] Trie树 php 实现敏感词过滤

    目录 背景 简介 存储结构 PHP 其他语言 字符串分割 示例代码 php 优化 缓存字典树 常驻服务 参考文章 背景 项目中需要过滤用户发送的聊天文本, 由于敏感词有将近2W条, 如果用 str_r ...

  4. DFA和trie特里实现敏感词过滤(python和c语言)

    今天的项目是与完成python开展,需要使用做关键词检查,筛选分类,使用前c语言做这种事情.有了线索,非常高效,内存小了,检查快. 到达python在,第一个想法是pip基于外观的c语言python特 ...

  5. web系统安全运营之基础- 基于DFA算法的高性能的敏感词,脏词的检测过滤算法类(c#).

    [概述]做好一个web系统的安全运维,除了常规的防注入,防入侵等,还有一个检测并过滤敏感词,脏词..  这件事做得不好,轻则导致一场投诉或纠纷,重则导致产品被勒令关闭停运. 废话少说,先看下代码,可以 ...

  6. 字典树Trie--实现敏感词过滤

    序言 Trie树 资料 https://blog.csdn.net/m0_37907797/article/details/103272967?utm_source=apphttps://blog.c ...

  7. 转:鏖战双十一-阿里直播平台面临的技术挑战(webSocket, 敏感词过滤等很不错)

    转自:http://www.infoq.com/cn/articles/alibaba-broadcast-platform-technology-challenges 鏖战双十一-阿里直播平台面临的 ...

  8. 用php实现一个敏感词过滤功能

    周末空余时间撸了一个敏感词过滤功能,下边记录下实现过程. 敏感词,一方面是你懂的,另一方面是我们自己可能也要过滤一些人身攻击或者广告信息等,具体词库可以google下,有很多. 过滤敏感词,使用简单的 ...

  9. 浅析敏感词过滤算法(C++)

    为了提高查找效率,这里将敏感词用树形结构存储,每个节点有一个map成员,其映射关系为一个string对应一个TreeNode. STL::map是按照operator<比较判断元素是否相同,以及 ...

随机推荐

  1. 微型 Python Web 框架 Bottle - Heroin blog

    微型 Python Web 框架 Bottle - Heroin blog 微型 Python Web 框架 Bottle

  2. 很少人知道的office专用卸载工具

    Microsoft Office是微软公司开发的一套基于 Windows 操作系统的办公软件套装.常用组件有 Word.Excel.Powerpoint等.当我们不需要再用了或者想安装旧版本的话,首先 ...

  3. 用c++语言编写函数 int index(char *s,char * t),返回字符串t在字符串s中出现的最左边的位置,如果s中没有与t匹配的子串,则返回-1。类似于索引的功能。

    首先,分析一下程序的思路: 1:从s的第i个元素开始,与t中的第1个元素匹配,如果相等,则将s的第i+1元素与t中的第2个元素匹配,以此类推,如果t所有元素都匹配,则返回位置i;否则,执行2; 2: ...

  4. C,C#,C++中&&和||,&和|的联系和区别

    本文来自:http://www.cnblogs.com/GT_Andy/archive/2010/03/30/1921805.html 两者计算结果相同(针对各自的运算对象),只是性能上有差别而已. ...

  5. mysql、sqlServer、hsql、oracle、db2各数据库支持的字段类型与最大精度

  6. java学习笔记day05

    1.final关键字:防止被继承的类或覆写的方法修改,变量或方法被final定义后  会在内在中存在 特点:   1)可以修饰类.函数.变量.   2)被final修饰的类不可以被继承.   3)被f ...

  7. Unity Layout碰撞检测

    第一次看到LayerMask根本不知道是什么东东,后来问问度娘,看了几篇文章,终于看明白一点点,在网上看到各路大神的解释,终于明白了,LayerMask实际上是一个位码操作,在Unity3d中Laye ...

  8. RDLC报表系列(一) 简单的动态数据绑定和配置

    RDLC系列链接 RDLC报表系列(一) 简单的动态数据绑定和配置  RDLC报表系列(二) 行分组 RDLC报表系列(三) 总计和折叠 RDLC报表系列(四) 矩阵 RDLC报表系列(五) 简单的图 ...

  9. Maximum Subarray (JAVA)

    Find the contiguous subarray within an array (containing at least one number) which has the largest ...

  10. .Net中如何使用MySql连接池

    提供一份官方的译文.翻译也挺辛苦的!! 6.4 Using Connector/Net with Connection Pooling 6.4在Connector/Net中使用连接池 The Conn ...