python中怎么替换字母_python如果含有两个相同字母,如何将其中一个替换成其他字符...

展开全部

采取的算法是:将第一和除其之外的每个字母对比,相同即记下替换后的62616964757a686964616fe4b893e5b19e31333335336364word,依次下推(第二和第三、第四。。。),逐个修改映射list# coding:utf8

if __name__ == '__main__':

words = ['school','google','getfileinfo','cherrypy','pypy']

print words

tmps = words#映射list,存放替换大小写后的list

index = 0#list遍历到第几个了

for wds in words:#遍历words

i = 0#记录list下的每个word长度

j = 0#记录每个word有几个相同的字母数

#下面采取的算法是:将第一和除其之外的每个字母对比,相同即记下替换后的word,依次下推(第二和第三、第四。。。),逐个修改映射list:tmps

for wd_a in wds[i:]:

for wd_b in wds[i+1:]:

if wd_a == wd_b:

# print wds, wd_a.upper()

j += 1

if j > 1:#相同字母超过一个的,需要沿用之前修改好的word,否则最后记录的将是最后一个相同字母转大写的word

tmp = tmp.replace(wd_a, wd_a.upper(), 1)

else:

tmp = wds.replace(wd_a, wd_a.upper(), 1)

# print tmp

tmps[index] = tmp #修改映射list:tmps

i += 1

index += 1

print tmps

运行结果:

['school', 'google', 'getfileinfo', 'cherrypy', 'pypy']

['schOol', 'GOogle', 'gEtFIleinfo', 'cheRrYpy', 'PYpy']

算法二:# coding:utf8

if __name__ == '__main__':

words = ['school','google','getfileinfo','cherrypy','pypy']

print words

tmps = words#映射list,存放替换大小写后的list

#算法二

#下面采取的算法是:先将单词序列化,然后排序,接着采取两两相比较,减少比较次数,同时遇到相同字母的就跳到下一组对比

index = 0

for word in words:

letters = []

for wd in word:

letters.append(wd)

letters.sort()

# print letters

j = 0

flag = False

for i in range(len(letters)-1):

if flag:

flag = False#重置跳过标记

continue#第一和第二位字母相同,那就没必要再比较第二和第三位字母了,直接跳过比较第三和第四位字母

# print letters[i],letters[i+1]

if letters[i] == letters[i+1]:

j += 1

if j > 1:

tmp = tmp.replace(letters[i], letters[i].upper(), 1)

else:

tmp = word.replace(letters[i], letters[i].upper(), 1)

# print tmp

tmps[index] = tmp

flag = True#jump flag

index += 1

print tmps

测试了下运行时间,words在145个时,运行时间对比:

Time2: 0.0160000324249

Time2: 0.0150001049042

Time2: 0.0149998664856

Time1: 0.0160000324249

Time1: 0.0159997940063

Time1: 0.0150001049042

可见算法二的最少运行时间比算法一少,要快

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值