iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python乱序字符串排序如何实现
  • 223
分享到

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

2023-07-04 12:07:51 223人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

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

本文小编为大家详细介绍“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乱序字符串排序如何实现”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网Python频道。

--结束END--

本文标题: python乱序字符串排序如何实现

本文链接: https://www.lsjlt.com/news/345131.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • python乱序字符串排序如何实现
    本文小编为大家详细介绍“python乱序字符串排序如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“python乱序字符串排序如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。python乱序字符串排序...
    99+
    2023-07-04
  • python乱序字符串排序的实现方式
    目录python乱序字符串排序什么是乱序字符串排序检查乱序字符串检查算法研究 解法一解法二解法三python乱序字符串排序 什么是乱序字符串排序 乱序字符串排序是指一个字符...
    99+
    2024-04-02
  • python字符串降序排序怎么实现
    可以使用sorted函数对字符串进行降序排序,然后使用join方法将排好序的字符重新组合成一个字符串。示例如下:pythons = ...
    99+
    2023-10-18
    python
  • Python怎么实现字符串排序
    小编给大家分享一下Python怎么实现字符串排序,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!python主要应用领域有哪些1、云计算,典型应用OpenStack...
    99+
    2023-06-14
  • 怎么用Python实现字符串排序
    今天小编给大家分享一下怎么用Python实现字符串排序的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。说明sort()方法对字...
    99+
    2023-06-30
  • PHP如何实现字符串反方向排序
    这篇文章给大家分享的是有关PHP如何实现字符串反方向排序的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。方法:1、使用strrev()函数反转字符串。2、先使用str_split()分割字符串到一个数组中,然后使用...
    99+
    2023-06-15
  • Java字符串字段升序排序怎么实现
    你可以使用Java中的`Arrays.sort()`方法来实现字符串字段的升序排序。以下是一个示例代码:```javaimport ...
    99+
    2023-09-14
    Java
  • php字符串实现数组排序
    排序是计算机科学中非常重要的操作。在 PHP 中,实现数组排序有多种方法,包括内置函数和自己编写排序算法。其中,字符串实现数组排序是一种特殊的方法。接下来我们将介绍如何使用字符串来实现数组的排序。字符串排序在 PHP 中,字符串排序使用 s...
    99+
    2023-05-19
  • 如何使用java实现字符串中的字母排序
    这篇文章主要介绍了如何使用java实现字符串中的字母排序的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何使用java实现字符串中的字母排序文章都会有所收获,下面我们一起来看看吧。题目要求java实现字符串中的...
    99+
    2023-07-06
  • oracle字符串按数字排序怎么实现
    要实现oracle字符串按数字排序,可以使用oracle的ORDER BY子句,并结合REGEXP_SUBSTR函数将字符串中的数字...
    99+
    2024-04-09
    oracle
  • java怎么实现字符串中的字母排序
    这篇文章主要介绍“java怎么实现字符串中的字母排序”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“java怎么实现字符串中的字母排序”文章能帮助大家解决问题。题目要求java实现字符串中的字母排序并...
    99+
    2023-07-05
  • 字符串之间的排序
    在求取以字符串为范围的结果时,对得到的结果有些困惑,搜到了一篇英文文档,这里稍加解释。SELECT * FROM emp WHERE ename BETWEEN ‘A’ AND ‘C’;因为...
    99+
    2024-04-02
  • Java实现字符串排序的几种方式
    创建实体类(此处引入了lombok) @Data@AllArgsConstructor@NoArgsConstructorpublic class Test{ private int Id; private String Tes...
    99+
    2023-09-14
    java 算法 排序算法
  • python中的list字符串元素排序
    目录list字符串元素排序注意事项对含有数字的字符串进行排序list字符串元素排序 需求:对list中的字符串按照首字母排序 实现: list1 = ['as,jj,bk'] for...
    99+
    2024-04-02
  • python字符串排序规则有哪些
    在Python中,字符串排序有以下几种规则:1. 字母顺序排序:按照字母的Unicode值进行排序。可以使用内置函数`sorted(...
    99+
    2023-09-26
    python
  • sql字符串转换为数字排序怎么实现
    要将SQL字符串转换为数字排序,可以使用CAST()函数将字符串转换为数字,然后进行排序。以下是一个示例: 假设有一个包含数字字符串...
    99+
    2024-04-09
    sql
  • oracle如何将字符串转化为数字排序
    在Oracle中,您可以使用TO_NUMBER函数将字符串转化为数字,然后对数字进行排序。以下是一个示例: SELECT c...
    99+
    2024-04-30
    oracle
  • JavaScript如何过滤并排序字符串列表
    小编给大家分享一下JavaScript如何过滤并排序字符串列表,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!过滤并排序字符串列表...
    99+
    2024-04-02
  • java如何将字符串从小到大排序
    可以使用Java中的Arrays类的sort方法来实现字符串数组的排序,具体步骤如下:1. 创建一个字符串数组,存储待排序的字符串。...
    99+
    2023-09-26
    java
  • Python 实现随机打乱字符串
    from random import shuffle def shuffle_str(s): # 将字符串转换成列表 str_list = list(s) # 调用random模块的shuffle函数打乱列表...
    99+
    2023-01-30
    字符串 Python
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作