从品牌网站建设到网络营销策划,从策略到执行的一站式服务
Python实现对变位词的判断,供大家参考,具体内容如下
网站建设哪家好,找创新互联建站!专注于网页设计、网站建设、微信开发、小程序制作、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了宜丰免费建站欢迎大家使用!什么是变位词呢?即两个单词都是由相同的字母组成,而各自的字母顺序不同,譬如python和typhon,heart和earth。
变位词的判断
既然我们知道了变位词的定义,那么接下来就是实现对两个单词是否是变位词进行判断了,以下展示变位词判断的几种解法:
1、逐字检查
将单词1中的所有字符逐个到单词2中检查是否存在对应字符,存在就标记
实现:将词2中存在的对应字符设置None,由于字符串是不可变类型,需要先将词2字符复制到列表中
时间复杂度:O(n^2)
def anagramSolution1(s1,s2): alist = list(s2) # 复制s2 pos1 = 0 stillok = True while pos1 < len(s1) and stillok: # 循环s1的所有字符 pos2 = 0 found = False # 初始化标识符 while pos2 < len(alist) and not found: # 与s2的字符逐个对比 if s1[pos1] == alist[pos2]: found = True else: pos2 = pos2 + 1 if found: alist[pos2] = None # 找到对应,标记 else: stillok = False # 没有找到,失败 pos1 = pos1 + 1 return stillok print(anagramSolution1('python','typhon'))
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图