java字符串搜索匹配問題?
問題描述
我有三萬多個詞匯和它們的詞性(就是動詞,名詞,形容詞或者副詞之類的),我想寫個函數(shù)把以參數(shù)的方式傳遞進(jìn)來的單詞進(jìn)行詞性分析,然后返回它的詞性。
public int analyze(String word){ // 這個地方應(yīng)該用什么來保存那三萬個詞匯 // 這個地方應(yīng)該用怎樣的數(shù)據(jù)結(jié)構(gòu)或算法來判斷word到底在不在我那個三萬個詞匯里面 // 怎么做才能功效地判斷出word的詞性 return wordType;}
詞匯-詞性表目前是單純的以行為單位的txt文件
word1 tword2 nword3 a
就這樣,我該怎么做呢,應(yīng)該用什么來存儲我的三萬行數(shù)據(jù),txt,json,xml,或者寫到代碼里面放到數(shù)組里面去呢?哪一個循環(huán)起來快一些,有什么好的建議?
問題解答
回答1:你的具體用途是怎樣的,經(jīng)常用到,注重查詢效率?可以用map放內(nèi)存吧
如果不經(jīng)常使用,可以按首字母將詞分割成幾個文件,每次查詢都可以定位到某個文件,更快一點。說實話,三萬其實挺小的,讀起來應(yīng)該不慢,再夸張點你可以放數(shù)據(jù)庫。
如果有更好的想法再回復(fù)你
回答2:可以試下hadoop的 map reduce 哦
相關(guān)文章:
1. docker - 各位電腦上有多少個容器啊?容器一多,自己都搞混了,咋辦呢?2. javascript - 關(guān)于apply()與call()的問題3. docker網(wǎng)絡(luò)端口映射,沒有方便點的操作方法么?4. 安全性測試 - nodejs中如何防m(xù)ySQL注入5. datetime - Python如何獲取當(dāng)前時間6. java - spring boot 如何打包成asp.net core 那種獨立應(yīng)用?7. docker start -a dockername 老是卡住,什么情況?8. javascript - nginx反向代理靜態(tài)資源403錯誤?9. java - 在用戶不登錄的情況下,用戶如何添加保存到購物車?10. 推薦好用mysql管理工具?for mac和pc
