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