zoukankan      html  css  js  c++  java
  • java 过滤字符串方法实现

     这样过滤:“你TMD,也太缺德了吧”过滤后“你***,也太缺德了吧”把骂人的脏话过滤成*号

      package test;

      import java.util.HashMap;

      /**

      * maxLength-需要过滤最长字符串的长度

      * filterStrs<string,string>-需要过滤字符串的集合,key为需要过滤字符串,value为过滤成的字符串如"*"

      * @author Administrator

      *

      */

      public class Test{

      private int maxLength;

      private HashMap<String,String> filterStrs=new HashMap<String,String>();

      /**

      * 初始化需要过滤掉*的数量

      */

      private String initStr(int n){

      StringBuffer sb=new StringBuffer();

      for(int i=0;i<n;i++){

      sb.append('*');

      }

      return sb.toString();

      }

      /**

      * str-被过滤得字符串

      * s-需要过滤得字符串

      * 获得剩下未过滤的字符串

      */

      private String getNextStr(String str,int start,int slength){

      if(start==0){

      str=str.substring(slength);

      }else if(start+slength<str.length()){

      str=str.substring(start+slength);

      }

      return str;

      }

      /**

      * str-被过滤得字符串

      * s-需要过滤得字符串

      * 获得过滤后的字符串

      */

      private StringBuffer getFilterStr(StringBuffer sb,String str,int start,String s){

      if(start!=0){

      sb.append(str.substring(0,start));

      }

      sb.append(filterStrs.get(s));

      return sb;

      }

      /**

      * str-被过滤的字符串

      * 过滤,并组合过滤后的字符串

      */

      public String filter(String str) {

      StringBuffer resultStr=new StringBuffer();

      for(int start=0;start<str.length();start++){

      for(int end=start+1;end<=str.length()&&end<=start+maxLength;end++){

      String s=str.substring(start, end);

      int slength=s.length();

      if(filterStrs.containsKey(s)){

      resultStr=getFilterStr(resultStr,str,start,s);

      str=getNextStr(str,start,slength);

      start=0;

      end=start;

      }

      }

      }

      resultStr.append(str);

      return resultStr.toString();

      }

      public void put(String key) {

      int keyLength=key.length();

      filterStrs.put(key, initStr(keyLength));

      if(keyLength>this.maxLength)

      maxLength=keyLength;

      }

      public static void main(String[] agrs){

      Test t=new Test();

      t.put("TMD");

      t.put("TNND");

      t.put("操");

      t.put("NND");

      System.out.println(t.filter("TMD,操,TNND.操..TMDTMDTMDTMD.tTNND.操TMDTNNDTNNDTNND操"));

      }

      }

  • 相关阅读:
    LeetCode 第 193 场周赛
    LeetCode 每日一题 15. 三数之和
    LeetCode 每日一题 739. 每日温度
    [转]邹承鲁院士写他是如何读文献
    LeetCode 每日一题 面试题46. 把数字翻译成字符串
    LeetCode 每日一题 990. 等式方程的可满足性
    传说中编程界的龙书、虎书、鲸书、魔法书…… 指的都是哪些?
    LeetCode 每日一题 238. 除自身以外数组的乘积
    C++ 关键字 explicit
    LeetCode 每日一题 837. 新21点
  • 原文地址:https://www.cnblogs.com/shenliang123/p/2226880.html
Copyright © 2011-2022 走看看