婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > Python容錯(cuò)的前綴樹(shù)實(shí)現(xiàn)中文糾錯(cuò)

Python容錯(cuò)的前綴樹(shù)實(shí)現(xiàn)中文糾錯(cuò)

熱門(mén)標(biāo)簽:電銷機(jī)器人錄音要學(xué)習(xí)什么 煙臺(tái)電話外呼營(yíng)銷系統(tǒng) 如何地圖標(biāo)注公司 預(yù)覽式外呼系統(tǒng) 銀川電話機(jī)器人電話 企業(yè)彩鈴地圖標(biāo)注 上海正規(guī)的外呼系統(tǒng)最新報(bào)價(jià) 外賣地址有什么地圖標(biāo)注 長(zhǎng)春極信防封電銷卡批發(fā)

介紹

本文使用 Python 實(shí)現(xiàn)了前綴樹(shù),并且支持編輯距離容錯(cuò)的查詢。文中的前綴樹(shù)只存儲(chǔ)了三個(gè)分詞,格式為 (分詞字符串,頻率) ,如:('中海晉西園', 2)、('中海西園', 24)、('中南海', 4),可以換成自己的文件進(jìn)行數(shù)據(jù)的替換。在查詢的時(shí)候要指定一個(gè)字符串和最大的容錯(cuò)編輯距離。

實(shí)現(xiàn)

class Word:
    def __init__(self, word, freq):
        self.word = word
        self.freq = freq

class Trie:
    def __init__(self):
        self.root = LetterNode('')
        self.START = 3

    def insert(self, word, freq):
        self.root.insert(word, freq, 0)

    def findAll(self, query, maxDistance):
        suggestions = self.root.recommend(query, maxDistance, self.START)
        return sorted(set(suggestions), key=lambda x: x.freq)


class LetterNode:
    def __init__(self, char):
        self.REMOVE = -1
        self.ADD = 1
        self.SAME = 0
        self.CHANGE = 2
        self.START = 3
        self.pointers = []
        self.char = char
        self.word = None

    def charIs(self, c):
        return self.char == c

    def insert(self, word, freq, depth):
        if ' ' in word:
            word = [i for i in word.split(' ')]
        if depth  len(word):
            c = word[depth].lower()
            for next in self.pointers:
                if next.charIs(c):
                    return next.insert(word, freq, depth + 1)
            nextNode = LetterNode(c)
            self.pointers.append(nextNode)
            return nextNode.insert(word, freq, depth + 1)
        else:
            self.word = Word(word, freq)

    def recommend(self, query, movesLeft, lastAction):
        suggestions = []
        length = len(query)

        if length >= 0 and movesLeft - length >= 0 and self.word:
            suggestions.append(self.word)

        if movesLeft == 0 and length > 0:
            for next in self.pointers:
                if next.charIs(query[0]):
                    suggestions += next.recommend(query[1:], movesLeft, self.SAME)
                    break

        elif movesLeft > 0:
            for next in self.pointers:
                if length > 0:
                    if next.charIs(query[0]):
                        suggestions += next.recommend(query[1:], movesLeft, self.SAME)
                    else:
                        suggestions += next.recommend(query[1:], movesLeft - 1, self.CHANGE)
                        if lastAction != self.CHANGE and lastAction != self.REMOVE:
                            suggestions += next.recommend(query, movesLeft - 1, self.ADD)
                        if lastAction != self.ADD and lastAction != self.CHANGE:
                            if length > 1 and next.charIs(query[1]):
                                suggestions += next.recommend(query[2:], movesLeft - 1, self.REMOVE)
                            elif length > 2 and next.charIs(query[2]) and movesLeft == 2:
                                suggestions += next.recommend(query[3:], movesLeft - 2, self.REMOVE)
                else:
                    if lastAction != self.CHANGE and lastAction != self.REMOVE:
                        suggestions += next.recommend(query, movesLeft - 1, self.ADD)
        return suggestions



def buildTrieFromFile():
    trie = Trie()
    rows = [('中海晉西園', 2),('中海西園', 24),('中南海', 4)]
    for row in rows:
        trie.insert(row[0], int(row[1]))
    return trie


def suggestor(trie, s, maxDistance):
    if ' ' in s:
        s = [x for x in s.split(' ')]
    suggestions = trie.findAll(s, maxDistance)
    return [str(x.word) for x in suggestions]


if __name__ == "__main__":
    trie = buildTrieFromFile()
    r = suggestor(trie, '中海晉西園', 1)
    print(r)

分析

結(jié)果打印:
['中海晉西園', '中海西園']

可以看出“中海晉西園”是和輸入完全相同的字符串,編輯距離為 0 ,所以符合最大編輯距離為 1 的要求,直接返回。

“中海西園”是“中海晉西園”去掉“晉”字之后的結(jié)果,編輯距離為 1, 所以符合最大編輯距離為 1 的要求,直接返回。

另外,“中南海”和“中海晉西園”的編輯距離為 4 ,不符合最大編輯距離為 1 的要求,所以結(jié)果中沒(méi)有出現(xiàn)。

參考

https://github.com/leoRoss/AutoCorrectTrie

到此這篇關(guān)于Python容錯(cuò)的前綴樹(shù)實(shí)現(xiàn)中文糾錯(cuò)的文章就介紹到這了,更多相關(guān)Python 中文糾錯(cuò)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python中文糾錯(cuò)的簡(jiǎn)單實(shí)現(xiàn)

標(biāo)簽:潮州 宜昌 佳木斯 西寧 上饒 湖北 珠海 盤(pán)錦

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python容錯(cuò)的前綴樹(shù)實(shí)現(xiàn)中文糾錯(cuò)》,本文關(guān)鍵詞  Python,容,錯(cuò)的,前綴,樹(shù),實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python容錯(cuò)的前綴樹(shù)實(shí)現(xiàn)中文糾錯(cuò)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Python容錯(cuò)的前綴樹(shù)實(shí)現(xiàn)中文糾錯(cuò)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    av亚洲精华国产精华精| 中文字幕av一区二区三区| 中文字幕一区三区| 欧美日韩一区三区| 成人一区二区三区视频在线观看| 一区二区激情视频| 中文字幕第一页久久| 制服丝袜亚洲精品中文字幕| 成人国产精品免费观看| 精品午夜久久福利影院| 日本系列欧美系列| 国产精品白丝在线| 久久久精品欧美丰满| 欧美一区二区三区公司| 欧美日韩中文国产| av午夜一区麻豆| 国产一区二区不卡在线 | 91精品国产手机| 欧美午夜精品久久久久久超碰| 国产精品77777| 国产在线乱码一区二区三区| 亚洲成a人v欧美综合天堂| 国产高清在线精品| 一区二区三区四区在线免费观看| 国产精品久久福利| 亚洲欧美视频一区| 亚洲精品高清在线观看| 欧美色综合天天久久综合精品| 成人一区二区视频| 国产精品18久久久| 成人综合婷婷国产精品久久免费| 国产99久久久国产精品潘金网站| 国产69精品一区二区亚洲孕妇| 国产一区二区伦理| a级精品国产片在线观看| 91啪九色porn原创视频在线观看| www.亚洲激情.com| 成人午夜激情片| 97成人超碰视| 欧美日韩视频第一区| 555夜色666亚洲国产免| 亚洲精品一区二区在线观看| 国产嫩草影院久久久久| 1区2区3区欧美| 亚洲高清免费观看| 久久国产精品99久久人人澡| 国产精品小仙女| 91免费在线看| 欧美一三区三区四区免费在线看| 日韩一区二区三区精品视频| 2020国产精品自拍| 亚洲欧洲美洲综合色网| 亚洲第四色夜色| 国产一区二区三区蝌蚪| 91蝌蚪porny成人天涯| 4hu四虎永久在线影院成人| 亚洲精品在线网站| 亚洲精品成人在线| 久久精品国产精品亚洲综合| 成人h动漫精品一区二区| 678五月天丁香亚洲综合网| 中文字幕欧美国产| 蜜桃av一区二区三区| 99这里只有久久精品视频| 777色狠狠一区二区三区| 国产精品久久久久久久久免费相片| 一区二区三区丝袜| 狠狠色丁香九九婷婷综合五月| 色偷偷成人一区二区三区91| 久久一区二区视频| 天天色图综合网| 91蜜桃免费观看视频| 精品国产sm最大网站免费看| 一区二区三区日本| av一二三不卡影片| 久久人人超碰精品| 男人的j进女人的j一区| 欧美三级日韩三级| 中文字幕制服丝袜一区二区三区| 免费在线欧美视频| 欧美在线观看你懂的| 亚洲欧洲日本在线| 成人综合在线视频| 国产日韩影视精品| 美女网站色91| 欧美日韩高清一区二区| 亚洲色图视频网站| 国产一区在线看| 欧美成人福利视频| 日韩精品91亚洲二区在线观看| 色婷婷精品久久二区二区蜜臂av| 亚洲国产精品成人久久综合一区| 美女视频黄 久久| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 精品国精品自拍自在线| 日韩二区三区在线观看| 欧美中文一区二区三区| 亚洲精品视频观看| 在线日韩av片| 亚洲国产一区二区三区| 91网站视频在线观看| 亚洲品质自拍视频| 日本二三区不卡| 亚洲激情自拍偷拍| 欧洲一区二区三区免费视频| 亚洲自拍偷拍图区| 欧美精品少妇一区二区三区| 奇米色一区二区三区四区| 欧美成人一级视频| 国产成人综合网站| 国产精品久久久久影视| 一本大道久久a久久综合婷婷 | 亚洲综合在线第一页| 欧美中文字幕一区二区三区亚洲| 亚洲一区在线观看免费| 欧美日韩高清一区二区三区| 美女网站色91| 国产精品女主播av| 91麻豆免费观看| 图片区小说区区亚洲影院| 日韩一级黄色片| 国产一区二区调教| 中文字幕一区二区三区不卡| 色哟哟国产精品| 美女视频免费一区| 国产精品久久久久久户外露出| 在线免费观看日本一区| 男人的天堂久久精品| 国产精品毛片久久久久久久| 欧美日韩在线播放| 国产在线看一区| 亚洲免费成人av| 日韩一二在线观看| 丁香啪啪综合成人亚洲小说| 一区二区欧美精品| 国产午夜精品久久久久久免费视| 91女神在线视频| 国内精品国产成人国产三级粉色| 中文av一区特黄| 欧美人与z0zoxxxx视频| 成人动漫一区二区| 美女视频一区二区| 一区二区在线观看免费| 亚洲精品一区二区三区四区高清| 色婷婷久久久亚洲一区二区三区| 麻豆精品国产91久久久久久| 综合久久国产九一剧情麻豆| 欧美mv日韩mv国产| 欧美写真视频网站| 不卡一区二区在线| 国产酒店精品激情| 视频一区二区三区中文字幕| 国产精品三级视频| 日韩欧美视频在线| 欧美亚洲国产一区在线观看网站 | 日韩不卡一区二区三区 | 91久久精品一区二区三| 国产一区二区h| 男男gaygay亚洲| 成人亚洲一区二区一| 视频一区二区欧美| 一区二区在线观看不卡| 国产精品区一区二区三| 精品国产污网站| 欧美一级艳片视频免费观看| 一本大道久久精品懂色aⅴ| 成人性生交大片免费看在线播放| 日韩av午夜在线观看| 亚洲黄色av一区| 亚洲靠逼com| 亚洲精品ww久久久久久p站| 成人免费在线观看入口| 一色桃子久久精品亚洲| 国产精品久久久久久久久晋中| 国产日韩欧美高清在线| 久久久综合激的五月天| 精品国产精品一区二区夜夜嗨| 6080午夜不卡| 日韩欧美在线1卡| 欧美成人一级视频| 久久―日本道色综合久久| 久久久高清一区二区三区| 久久精品男人天堂av| 26uuu欧美| 国产婷婷一区二区| 国产精品三级av在线播放| 国产精品视频在线看| 国产精品国产三级国产三级人妇| 国产精品毛片久久久久久| 国产精品视频免费看| 国产精品视频一二三| 亚洲乱码一区二区三区在线观看| 一区二区三区久久| 亚洲国产人成综合网站| 丝袜a∨在线一区二区三区不卡| 亚洲综合视频在线| 三级欧美在线一区| 麻豆精品国产91久久久久久| 国产精品66部| 91视频免费观看|