Re: [問題] 關於幾個 字串置換的問題
你簡繁互轉的機制是每個字元替換,沒有詞的處理,
若使用replace多了許多無用的查找比對。
試試使用Map來處理關係:
private static final Map<Character,Character> T2S=new HashMap();
private static final Map<Character,Character> S2T=new HashMap();
static {
final char[] UTF8T="...".toCharArray();
final char[] UTF8S="...".toCharArray();
for(int i=0,n=Math.min(UTF8T.length,UTF8S.length);i<n;i++){
final Character cT=Character.valueOf(UTF8T[i]);
final Character cS=Character.valueOf(UTF8S[i]);
T2S.put(cT,cS);
S2T.put(cS,cT);
}
}
private static String translate(
String text,Map<Character,Character> dictionary){
final char[] chars=text.toCharArray();
for(int i=0,n=chars.length;i<n;i++){
final Character found=dictionary.get(chars[i]);
if(null!=found)chars[i]=found;
}
return String.valueOf(chars);
}
public static String s2t(String simp){ return translate(simp,S2T); }
public static String t2s(String trad){ return translate(trad,T2S); }
※ 引述《pupuliao (pupu)》之銘言:
: 感謝
: 這是我的code
: private static String UTF8T="";//這裡放繁體字和簡體字的列表
: private static String UTF8S="";//大約兩千五百字....
: private String[] T= new String [UTF8T.length()];
: private String[] S= new String [UTF8S.length()];
: public Encoding(){//元件初始化的時候,分割放入陣列中
: for (int n=0;n<UTF8T.length();n++){
: T[n]=String.valueOf(UTF8T.charAt(n));
: S[n]=String.valueOf(UTF8S.charAt(n));
: }
: }
: /*簡轉繁*/
: public String StoT(String data){
: int n;
: String temp=data;
: for (n=0;n<UTF8T.length();n++){
: temp=temp.replaceAll(S[n],T[n]);
: }
: return temp;
: }
: /*繁轉簡*/
: public String TtoS(String data){
: int n;
: String temp=data;
: for (n=0;n<UTF8T.length();n++){
: temp=temp.replaceAll(T[n],S[n]);
: }
: return temp;
: }
: 我知道我的方法還滿.....暴力的,但一直找不到比較快的方法
: 現在的做法只有跑多線程 讓他加快完成
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 118.168.65.219
推
09/09 20:23, , 1F
09/09 20:23, 1F
推
09/09 20:25, , 2F
09/09 20:25, 2F
推
09/09 20:35, , 3F
09/09 20:35, 3F
推
09/09 20:55, , 4F
09/09 20:55, 4F
→
09/09 20:56, , 5F
09/09 20:56, 5F
→
09/09 22:59, , 6F
09/09 22:59, 6F
推
09/09 23:24, , 7F
09/09 23:24, 7F
討論串 (同標題文章)
本文引述了以下文章的的內容:
完整討論串 (本文為第 4 之 4 篇):