python乱序字符串排序的实现方式
作者:梦入玄机 发布时间:2023-08-02 12:14:59
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 True
print(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 False
print(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 False
print(foo('aacf','cfaa'))
时间复杂度:由于没有循环嵌套也没有排序等算法,时间复杂度为2n+26,即O(n)
代码优化:
def is_simlar(s1, s2):
from collections import Counter
return Counter(s1) == Counter(s2)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
来源:https://blog.csdn.net/qq_36255988/article/details/88290282


猜你喜欢
- 前言本文用Python实例阐述了一些关于进程、线程和协程的概念,由于水平有限,难免出现错漏,敬请批评改正。前提条件熟悉Python基本语法熟
- udp实现同时收发信息import socketimport threadingdef fa(udp_socket,recv_ip,recv
- 问题如何设定matplotlib输出的图片大小?import matplotlib.pyplot as plt一、plt.figure(fi
- 作者:F. Permadi译者:Sheneyan(子乌)英文原文: INTRODUCTION TO JavaScript Functions
- 一、InnoDB的表级锁在绝大多数情况下应该使用行锁,因为事务和行锁往往是选择InnoDB的理由,但个别情况下也使用表级锁。事务需要更新大部
- 1.创建表:drop table if exists photo;CREATE TABLE photo (  
- 本文实例讲述了mysql存储过程原理与使用方法。分享给大家供大家参考,具体如下:存储过程包含了一系列可执行的sql语句,存储过程存放于MyS
- 本文实例为大家分享了python实现通讯录管理系统的具体代码,供大家参考,具体内容如下题目期末项目 一. 项目要求利用函数实现通讯
- 大家都知道Python运行速度很慢,但是轮子多,因此用户十分广泛,在各种领域上都能用到Python,但是最头疼的还是,解决运行速度问题,因此
- 自己写了一下,适用而已,不太好,应该还能优化。先自己记录一下。不说废话了,直接贴代码最好:/* * 获得时间差,时间格式为 年-月
- ubuntu上安装mysql非常简单只需要几条命令就可以完成。1. sudo apt-get install mysql-server2.
- Python 网络请求模块 urllib 、requestsPython 给人的印象是抓取网页非常方便,提供这种生产力的,主要依靠的就是 u
- 需求背景业务表tb_image部分数据如下所示,其中id唯一,image_no不唯一。image_no表示每个文件的编号,每个文件在业务系统
- Go语言中符号 “ ^ ” 不再用于次方,而是表示“按位异或的运算”具体的运算规则如下:按位异或 ^ : 两位一个为 0, 一个为 1 ,结
- 今天训练faster R-CNN时,发现之前跑的很好的程序(是指在运行程序过程中,显卡利用率能够一直维持在70%以上),今天看的时候,显卡利
- selenium主要是用来做自动化测试,支持多种浏览器,爬虫中主要用来解决JavaScript渲染问题。模拟浏览器进行网页加载,当reque
- 众所周知,程序在启动后,各个程序文件都会被加载到内存中,这样如果程序文本再次变化,对当前程序的运行没有影响,这对程序是一种保护。但是,对于像
- 标准的SQL模式匹配SQL的模式匹配允许你使用“_”匹配任何单个字符,而“%”匹配任意数目字符(包括零个字符)。在 MySQL中,SQL的模
- 打开文件操作文件1打开文件时,需要指定文件路径和打开方式打开方式:r:只读w:只写a:追加“+”表示可以同时读写某个文件r+:读写w+:写读
- 对想要在可视化的环境下制作复杂网页的专业网页制作者来说,Dreamweaver 已经渐渐在网页编辑工具市场中展露头角,成为专业人士