一、 什么是乱序字符串排序
乱序字符串排序是指一个字符串是另一个字符串的乱序排序,比如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