文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

python乱序字符串排序如何实现

2023-07-04 12:31

关注

本文小编为大家详细介绍“python乱序字符串排序如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“python乱序字符串排序如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

python乱序字符串排序

什么是乱序字符串排序

乱序字符串排序是指一个字符串是另一个字符串的乱序排序,比如apple就是eppal的乱序字符串。

检查

假设字符串由26个小写字符串组成。

1、时间复杂度O(n^2)

解决方案:

判断两个字符串长度是否相等,若不相等返回False,不相等则判断第一个字符串的字符是否在第二个字符串中,如果不在,返回False,如果在则把第二个字符串中查找的位置元素置为None,因为要改变第二个字符串,需把第二个字符串转换为list,代码如下:

def none_sort_str(s1, s2):    s2_list = list(s2)    if len(s1) != len(s2):        return False    else:        for i in range(len(s1)):            for j in range(len(s2_list)):                if s1[i] in s2_list:                    s2_list[s2_list.index(s1[i])] = None                    break                else:                    return False    return True

2、时间复杂度O(n)

解决方案:

判断两个字符串长度是否相等,若不相等返回False,使用计数方式,代码如下:

def none_sort_str2(s1, s2):    a = [0] * 26    b = [0] * 26    for i in range(len(s1)):        index1 = ord(s1[i]) - ord('a')        a[index1] += 1    for i in range(len(s2)):        index2 = ord(s2[i]) - ord('a')        b[index2] += 1    if a == b:        return True    else:        return False

乱序字符串检查算法研究 

显示不同量级的算法的一个很好的例子是字符串的乱序检查。乱序字符串是指一个字符串只是另一个字符串的重新排列。

例如,'heart' 和 'earth' 就是乱序字符串。'python' 和 'typhon' 也是。为了简单起见,我们假设所讨论的两个字符串具有相等的长度,并且他们由 26 个小写字母集合组成。我们的目标是写一个布尔函数,它将两个字符串做参数并返回它们是不是乱序。

解法一

思路:将两个字符串都转化成列表,然后遍历其中一个,当前元素在另外一个列表中就把另一个列表的对应元素移除(防止重复干扰)。不存在就返回FALSE,遍历完成返回True

代码参考如下:

str1 = 'hagjen'str2 = 'ahejng'def foo(str1,str2):    ls1 = list(str1)    ls2 = list(str2)    for i in ls1:        if i in ls2:            ls2.remove(i)        else:return False    return Trueprint(foo(str1,str2))

算法复杂度:两层for循环,都是和n线性相关,所以这个算法复杂度为 O(n^2 )。

解法二

两个字符串也都转为列表,然后排序当排序后连个列表相等就返回True,否则FALSE

str1 = 'hagjen'str2 = 'ahejng'def foo(str1,str2):    ls1 = list(str1).sort()    ls2 = list(str2) .sort()    return True if ls1==ls2 else Falseprint(foo(str1,str2))

算法复杂度:咋一看完全没有循环,复杂度好像非常低,但是别忘了排序!排序是python内部实现的,它也需要时间消耗,排序的算法复杂度一般是O(nlog(n)),O(n^2)。所以这种方法不一定比上面的好

解法三

建立两个长度为26的列表,分别遍历两个字符串,分别计数,最后两个列表相同就返回True

def foo(s1,s2):    ls1 = list(s1)    ls2 = list(s2)    count1 = [0 for  i in range(26)]    count2 = [0 for  i in range(26)]    print(count1)    print(count2)    for  i in ls1:        count1[ord(i)-ord('a')] +=1    for  i in ls2:        count2[ord(i)-ord('a')] +=1    return True if count1==count2 else Falseprint(foo('aacf','cfaa'))

时间复杂度:由于没有循环嵌套也没有排序等算法,时间复杂度为2n+26,即O(n)

代码优化:

def is_simlar(s1, s2):    from collections import Counter    return Counter(s1) == Counter(s2)

读到这里,这篇“python乱序字符串排序如何实现”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯