Re: [問題] 關於幾個 字串置換的問題

看板java作者 (人比人Cheese人)時間13年前 (2012/09/08 22:11), 編輯推噓5(502)
留言7則, 2人參與, 最新討論串4/4 (看更多)
你簡繁互轉的機制是每個字元替換,沒有詞的處理, 若使用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
感謝阿~~假日沒開PTT,一回來就看到這篇
09/09 20:23, 1F

09/09 20:25, , 2F
測試結果 比前一位提供的方法又提高了9~10倍
09/09 20:25, 2F

09/09 20:35, , 3F
我可以把這段code 放到我的部落格上去嗎?
09/09 20:35, 3F

09/09 20:55, , 4F
雖然還沒完全搞動 hashmap的運作方式,但是終於知道
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
文章代碼(AID): #1GIr7u1y (java)
討論串 (同標題文章)
文章代碼(AID): #1GIr7u1y (java)