看板 java 關於我們 聯絡資訊
你簡繁互轉的機制是每個字元替換,沒有詞的處理, 若使用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