检查字符串是否可以重新排列以在 Python 中形成特殊的回文
假设我们有一个字符串;我们必须检查给定字符串的字符是否可以打乱以形成回文。
因此,如果输入类似于s="aarcrce",那么输出将为True,因为我们可以将字符打乱以形成“racecar”,这是一个回文。
为了解决这个问题,我们将按照以下步骤操作-
大小:=256
freq:=大小为256的数组并填充为0
对于范围0到s大小的i,请执行
将freq数组中字符s[i]的频率增加1
奇数:=0
对于范围0到大小的i,请执行
返回错误
奇数:=奇数+1
如果freq[i]是idd,那么
如果odd_count>1,则
返回真
让我们看看以下实现以获得更好的理解-
示例
size = 256
def solve(s) :
freq = [0] * size
for i in range( 0, len(s)) :
freq[ord(s[i])] = freq[ord(s[i])] + 1
odd_count = 0
for i in range(0, size) :
if freq[i] % 2 == 1 :
odd_count = odd_count + 1
if odd_count > 1:
return False
return True
s = "aarcrce"
print(solve(s))输入
"aarcrce"输出结果
True
热门推荐
10 茶人生日祝福语简短
11 友谊晚上祝福语大全简短
12 中式蛋糕开业祝福语简短
13 比赛结束花束祝福语简短
14 上嫂子生日祝福语简短
15 圣诞祝福语简短小学
16 家庭英语祝福语短句简短
17 婚庆花篮祝福语简短大气
18 创业失败返乡祝福语简短