久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

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

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

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

使用遞歸實現(xiàn)

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’]

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

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 排序最長英文單詞鏈內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 霍林郭勒市| 哈尔滨市| 新化县| 福贡县| 盘锦市| 宁国市| 中牟县| 图木舒克市| 新沂市| 新闻| 奇台县| 新乡市| 清苑县| 安龙县| 广丰县| 曲周县| 万盛区| 宣化县| 南安市| 凭祥市| 竹北市| 徐汇区| 兰考县| 远安县| 南京市| 安仁县| 桐梓县| 迁西县| 西乌| 疏勒县| 墨脱县| 泸西县| 德钦县| 仙桃市| 南康市| 邯郸市| 合阳县| 东乡县| 辽源市| 八宿县| 富锦市|