字符串的排列是怎样的
发表于:2024-11-15 作者:千家信息网编辑
千家信息网最后更新 2024年11月15日,字符串的排列是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。输入一个字符串,按字典序打印出该字符串中字符的所有排列
千家信息网最后更新 2024年11月15日字符串的排列是怎样的
字符串的排列是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
# -*- coding: utf-8 -*-# @Time : 2019-07-08 9:52# @Author : Jayce Wong# @ProjectName : job# @FileName : stringPermutation.py# @Blog : https://blog.51cto.com/jayce1111# @Github : https://github.com/SysuJayceclass Solution: """ 遇到这种排列的题目,可以通过分治的方法,利用递归进行解决。 将待排列的字符串(n位)看成两部分组成,第一部分包含首字符(1),第二部分包含剩余字符(n-1) 然后固定第一部分,对第二部分进一步排列。这时就是递归开始了。 这里递归的核心就是每次选一个字符作为第一部分,然后剩余字符作为第二部分。 递归的出口为:第二部分包含字符为0个,也就是字符串的所有字符都排列过了。 """ def Permutation(self, ss): """ 对给定字符串进行全排列 :param ss: 带排列字符串 :return: 一个列表,包含所有可能的排列,其中元素顺序符合字典序 """ def helper(s, begin): # 这里将递归出口设置为第二部分的起始下标超过合法界限 if begin >= len(s): ans.add(''.join(s)) else: # 从给定的起点开始,将后面的所有字符依次和起点的字符交换,然后对交换后的第二部分 # 字符串进行排列(递归) for idx in range(begin, len(s)): s[idx], s[begin] = s[begin], s[idx] helper(s, begin + 1) # 记得在一次交换结束后应该将字符串还原成交换前的顺序,否则这个循环不能保证 # 所有字符都能依次和起点字符交换 s[idx], s[begin] = s[begin], s[idx] if not ss: return [] ans = set() helper(list(ss), 0) return sorted(list(ans))def main(): s = "abc" solution = Solution() ans = solution.Permutation(s) print(ans)if __name__ == '__main__': main()
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。
字符
字符串
二部
递归
第一部
起点
字典
就是
顺序
进一
出口
剩余
帮助
输入
合法
清楚
下标
也就是
元素
内容
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
bfd是什么网络技术
dnf手游挤进服务器
回民区政府网络安全和信息化
手机软件开发公司哪
软件开发合同 增值税
服务器无法进入系统
服务业软件开发
网络安全课 微信
数据库语言查询入门
杭州雷鸟科技工业互联网
怎么使用硬盘搭建服务器
网络安全案例 学生
饭店网络安全论文
中学生网络安全问题的危害
鸿瑞网络安全隔离装置
为什么软件开发管理难
关系数据库理论 pdf
如何办理通勤人员数据库
php对数据库的函数
机关网络安全会议纪要
c语言软件开发游戏过程
中国网络安全的建议
最新网络安全法全文下载
软件开发中专院校
两个数据库表的联合修改
加速器出现服务器不在线
网络安全伴我行手抄报模板
爬虫爬取知网数据库
数据库如何与上位机通信
车品投广州网络技术有限公司