国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

Python 排序最長英文單詞鏈(列表中前一個單詞末字母是下一個單詞的首字母)

瀏覽:6日期:2022-07-02 11:56:33

使用遞歸實現

words = [’giraffe’, ’elephant’, ’ant’, ’tiger’, ’racoon’, ’cat’, ’hedgehog’, ’mouse’]def get_results(_start, _current, _seen): if all(c in _seen for c in words if c[0] == _start[-1]): yield _current else: for i in words: if i[0] == _start[-1]: yield from get_results(i, _current+[i], _seen+[i])new_d = [list(get_results(i, [i], []))[0] for i in words]final_d = max([i for i in new_d if len(i) == len(set(i))], key=len)

輸出:

[’hedgehog’, ’giraffe’, ’elephant’, ’tiger’, ’racoon’]

工作原理類似于廣度優先搜索,因為只要當前值之前沒有被調用,get_results函數就會繼續遍歷整個列表。函數已經查找過的值被添加到_seen列表中,最終停止遞歸調用流。這個解決方案也會忽略重復的結果,

words = [’giraffe’, ’elephant’, ’ant’, ’ning’, ’tiger’, ’racoon’, ’cat’, ’hedgehog’, ’mouse’,]new_d = [list(get_results(i, [i], []))[0] for i in words]final_d = max([i for i in new_d if len(i) == len(set(i))], key=len)

輸出:

[’ant’, ’tiger’, ’racoon’, ’ning’, ’giraffe’, ’elephant’]

到此這篇關于Python 排序最長英文單詞鏈(列表中前一個單詞末字母是下一個單詞的首字母)的文章就介紹到這了,更多相關Python 排序最長英文單詞鏈內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 日照市| 渭源县| 锡林浩特市| 克东县| 长子县| 峨眉山市| 乐都县| 龙口市| 策勒县| 弥勒县| 营口市| 乌鲁木齐县| 平罗县| 上虞市| 台山市| 商河县| 临城县| 安图县| 仁寿县| 安多县| 新宾| 罗甸县| 昌平区| 凌源市| 平顺县| 德昌县| 南澳县| 河池市| 邵阳县| 新密市| 东城区| 邻水| 九龙城区| 南城县| 大足县| 桃园市| 昌吉市| 繁峙县| 霍邱县| 哈尔滨市| 射阳县|