Python 找出英文单词列表(list)中最长单词链
本文主要介绍Python中单词字符串的列表(list),找出列表中所有单词中前一个单词首字母和后一个单词尾字母相同,组成最长的单词链方法代码,并且每个单词不能多次使用。
例如:
words = [’giraffe’, ’elephant’, ’ant’, ’tiger’, ’racoon’, ’cat’, ’hedgehog’, ’mouse’]
最长的单词链列表:
[’hedgehog’, ’giraffe’, ’elephant’, ’tiger’, ’racoon’]1、用递归方法查找
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’]
2、使用networkx查找import networkx as nximport matplotlib.pyplot as pltwords = [’giraffe’, ’elephant’, ’ant’, ’tiger’, ’racoon’, ’cat’, ’hedgehog’, ’mouse’]G = nx.DiGraph()G.add_nodes_from(words)for word1 in words: for word2 in words: if word1 != word2 and word1[-1] == word2[0]: G.add_edge(word1, word2)nx.draw_networkx(G)plt.show()print(nx.algorithms.dag.dag_longest_path(G))
到此这篇关于Python 找出英文单词列表(list)中最长单词链的文章就介绍到这了,更多相关Python 列表最长单词链内容请搜索好吧啦网以前的文章或继续浏览下面的相关文章希望大家以后多多支持好吧啦网!
相关文章:
1. python matplotlib工具栏源码探析二之添加、删除内置工具项的案例2. php去掉数组的第一个值的两个函数:array_shift、array_splice3. Python unittest生成测试报告过程解析4. 解决VUE项目使用Element-ui 下拉组件的验证失效问题5. 如何基于python3和Vue实现AES数据加密6. Django-simple-captcha验证码包使用方法详解7. CSS Hack大全-教你如何区分出IE6-IE10、FireFox、Chrome、Opera8. CSS3实例分享之多重背景的实现(Multiple backgrounds)9. 用PHP读取和编写XML DOM10. uni-app结合PHP实现单用户登陆demo及解析

网公网安备