我不知道你是要自己實現(xiàn),還是說只要有個類庫就可以了,下面是我找的一個類庫的實例代碼:

成都創(chuàng)新互聯(lián)公司秉承實現(xiàn)全網(wǎng)價值營銷的理念,以專業(yè)定制企業(yè)官網(wǎng),網(wǎng)站建設、成都網(wǎng)站制作,重慶小程序開發(fā)公司,網(wǎng)頁設計制作,成都做手機網(wǎng)站,成都全網(wǎng)營銷推廣幫助傳統(tǒng)企業(yè)實現(xiàn)“互聯(lián)網(wǎng)+”轉型升級專業(yè)定制企業(yè)官網(wǎng),公司注重人才、技術和管理,匯聚了一批優(yōu)秀的互聯(lián)網(wǎng)技術人才,對客戶都以感恩的心態(tài)奉獻自己的專業(yè)和所長。
package?test3;
import?net.sf.chineseutils.ChineseUtils;
public?class?Test?{
public?static?void?main(String?args[])?throws?Exception{
System.out.println(ChineseUtils.simpToTrad("把BIG5繁體字符串轉換成的GB簡體字符串。"));
}
}
輸出:
把BIG5繁體字符串轉換成的GB簡體字符串。
[\u4e00-\u9fa5]
這個可以判斷是不是漢字,我測試時,不能區(qū)分簡繁。
找到下邊這些JS的正則。(測試也區(qū)分不了簡繁。)
[\u2E80-\u9FFF]+$ 匹配所有東亞區(qū)的語言
[\u4E00-\u9FFF]+$ 匹配簡體和繁體
[\u4E00-\u9FA5]+$ 匹配簡體
希望能你有點幫助,我再找找怎么區(qū)分簡繁。
實現(xiàn)思路一:采用字符串的方式實現(xiàn)
[java]?view?plain?copy
package?com.bzu.converter;??
import?java.util.Scanner;??
/**?
*?思路一:采用字符串的方式實現(xiàn)?
*/??
public?class?JianFanConvert1?{??
public?static?final?String?jianti?=?"萬與丑專業(yè)叢東絲";??
public?static?final?String?fanti?=?"萬與丑專業(yè)叢東絲";
public?static?void?main(String[]?args)?{??
Scanner?input?=?new?Scanner(System.in);??
System.out.println("請輸入你想轉換的句子");??
String?words?=?input.next();??
for?(int?i?=?0;?i??words.length();?i++)?{??
char?tempChar?=?words.charAt(i);??
int?position?=?jianti.indexOf(tempChar);//此方法調用時間復雜度為O(n)??
char?fantiChar;??
if?(position?==?-1)?{??
fantiChar?=?tempChar;??
}?else?{??
fantiChar?=?fanti.charAt(position);??
}??
System.out.print(fantiChar);??
}??
}??
}??
分析上述實現(xiàn),時間復雜度為O(n*n),當問題規(guī)模擴大時會非常耗時。
實現(xiàn)思路二:采用哈希算法實現(xiàn)
1.哈希方法
哈希方法在就是在鍵和值之間建立一個確定的對應函數(shù)關系hash(),就是key向value的換算關系,使得每一個鍵與結構中的一個唯一的存儲位置相對應:值的存儲位置=hash(鍵)即Value的位置=hash(key)
例如有一組“鍵值對”:5,”tom”、8,”Jane”、12,”Bit”、17,”Lily”、20,”sunny”,我們按照如下哈希函數(shù)對鍵進行計算:hash(x)=x%17+3,得出如下結果:hash(5)=8、hash(8)=11、hash(12)=15、hash(17)=3、hash(20)=6。
我們把5,”tom”、8,”Jane”、12,”Bit”、17,”Lily”、20,”sunny”分別放到地址為8、11、15、3、6的位置上。當要檢索17對應的值的時候,只要首先計算17的哈希值為3,然后到地址為3的地方去取數(shù)據(jù)就可以找到17對應的數(shù)據(jù)是“Lily”了。
使用哈希方法,查詢的時間復雜度為O(1),能夠直接定位其位置,大大加快數(shù)據(jù)的查詢速度。
2.哈希表
將數(shù)據(jù)采用哈希算法進行保存的數(shù)據(jù)結構就是哈希表,常見操作put、get、remove。
Java中的HashMap使用(Java內(nèi)置的哈希表數(shù)據(jù)結構)
HashMap的主要方法
int?size():得到Map中“鍵-值對”的數(shù)量
boolean?isEmpty():Map是否是空的,也就是是否不含有任何“鍵-值對”
boolean?containsKey(Object?key):Map中是否含有以key為鍵的“鍵-值對”
boolean?containsValue(Object?value):Map中是否含有以value為值的“鍵-值對”
Object?get(Object?key):從Map中得到以key為鍵的值,如果Map中不含有以key為鍵的“鍵-值對”則返回null
Object?put(Object?key,?Object?value):向Map中存儲以key為鍵、value為值的“鍵-值對”
Object?remove(Object?key):從Map中移除以key為鍵的“鍵-值對”
void?clear():清除所有“鍵-值對”
Set?keySet():得到所有的鍵
Collection?values():得到所有的值
Set?entrySet():得到所有的“鍵-值對”,Set中的類型是Map.Entry
[java]?view?plain?copy
package?com.bzu.converter;??
import?java.util.HashMap;??
import?java.util.Map;??
import?java.util.Scanner;??
/**?
*?思路二:采用哈希算法實現(xiàn)?
*/??
public?class?JianFanConvert2?{??
public?static?final?String?jianti?=?"萬與丑專業(yè)叢東絲";??
public?static?final?String?fanti?=?"萬與丑專業(yè)叢東絲";??
public?static?void?main(String[]?args)?{??
MapCharacter,?Character?map=new?HashMapCharacter,?Character();??
for(int?i=0;ijianti.length();i++){??
map.put(jianti.charAt(i),fanti.charAt(i));??
}??
Scanner?input?=?new?Scanner(System.in);??
System.out.println("請輸入你想轉換的句子");??
String?words?=?input.next();??
/**?
*?為了測試隨著問題規(guī)模的擴大用時?
*/??
for(int?i=0;i10;i++){??
words=words+words;??
}??
long?begin=System.currentTimeMillis();??
for?(int?i?=?0;?i??words.length();?i++)?{??
char?tempChar?=?words.charAt(i);??
Character?character=map.get(tempChar);??
char?fantiChar;??
if?(character?==?null)?{??
fantiChar?=?tempChar;??
}?else{??
fantiChar=character;??
}??
System.out.print(fantiChar);??
}??
long?end=System.currentTimeMillis();??
System.out.println("\n用時:"+(end-begin));??
}??
}??
分析上述算法實現(xiàn),時間復雜度變?yōu)閛(n)
問題探討:
為什么算法復雜度由O(n*n)變成O(n),但是實際執(zhí)行時間沒有明顯的變化?
print,數(shù)據(jù)在CPU、內(nèi)存中運算都非常快,一旦與外設(打印機、網(wǎng)絡(網(wǎng)卡)、顯示設備(顯卡))交換數(shù)據(jù),速度就會慢很多
來自
junjunguoguo的專欄
網(wǎng)頁標題:java代碼識別繁體字 java簡體中文轉繁體
URL鏈接:http://www.chinadenli.net/article32/dddpjsc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供標簽優(yōu)化、自適應網(wǎng)站、網(wǎng)站建設、面包屑導航、做網(wǎng)站、網(wǎng)站設計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)