作者ClareQ (人比人Cheese人)
看板java
標題Re: [問題] 關於幾個 字串置換的問題
時間Sat Sep 8 22:11:01 2012
你簡繁互轉的機制是每個字元替換,沒有詞的處理,
若使用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
推 pupuliao:感謝阿~~假日沒開PTT,一回來就看到這篇 09/09 20:23
推 pupuliao:測試結果 比前一位提供的方法又提高了9~10倍 09/09 20:25
推 pupuliao:我可以把這段code 放到我的部落格上去嗎? 09/09 20:35
推 pupuliao:雖然還沒完全搞動 hashmap的運作方式,但是終於知道 09/09 20:55
→ pupuliao:這隻程式碼的運作原理了 09/09 20:56
→ ClareQ:可以啊 沒什麼特別的東西ㄟ... 09/09 22:59
推 pupuliao:寫部落格 是給未來的自己看得@.@ 09/09 23:24