python非递归全排列实现方法

发布时间 - 2026-01-11 00:34:47    点击率:

刚刚开始学习python,当前看到了函数这一节。结合数组操作,写了个非递归的全排列生成。原理是插入法,也就是在一个有n个元素的已有排列中,后加入的元素,依次在前,中,后的每一个位置插入,生成n+1个新的全排列。因为Python切割数组或者字符串,以及合并比较方便,所以,程序会节省很多代码。

def getArrayInsertCharToStr(STR,CHAR):
  arr =[]
  s_len = len(STR)
  index =0
  while index <= s_len:
    #分割字符串
    arr.append(STR[:index]+CHAR+STR[index:s_len])
    index = index + 1
  return arr  

def getArrayInsertCharToArray(array,CHAR):
  index = 0
  re_array = []
  while index < len(array):
    re_array = re_array + getArrayInsertCharToStr(array[index],CHAR)
    index = index + 1
  return re_array       

def getPermutation(STR):
    resultArr = [STR[0]]
    for item in STR[1:]:
      resultArr = getArrayInsertCharToArray(resultArr,item)
    return   resultArr


print(getPermutation('abc'))

以上这篇python非递归全排列实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# python  # 递归  # 全排列  # python递归全排列实现方法  # python使用递归解决全排列数字示例  # Python递归生成全排列序列实操  # 给大家  # 是在  # 也就  # 已有  # 希望能  # 写了  # 这篇  # 在前  # 小编  # 大家多多  # 看到了  # 这一节  # py  # brush  # getArrayInsertCharToStr  # def 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 使用PHP下载CSS文件中的所有图片【几行代码即可实现】  网站建设要注意的标准 促进网站用户好感度!  Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】  EditPlus中的正则表达式实战(5)  Laravel怎么连接多个数据库_Laravel多数据库连接配置  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  Java解压缩zip - 解压缩多个文件或文件夹实例  Python并发异常传播_错误处理解析【教程】  如何在云主机上快速搭建网站?  网站建设保证美观性,需要考虑的几点问题!  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  HTML 中动态设置元素 name 属性的正确语法详解  Laravel中间件如何使用_Laravel自定义中间件实现权限控制  javascript日期怎么处理_如何格式化输出  Python3.6正式版新特性预览  Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知  Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程  Laravel如何实现API速率限制?(Rate Limiting教程)  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  开心动漫网站制作软件下载,十分开心动画为何停播?  5种Android数据存储方式汇总  Laravel安装步骤详细教程_Laravel环境搭建指南  Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】  如何快速辨别茅台真假?关键步骤解析  C++时间戳转换成日期时间的步骤和示例代码  个人网站制作流程图片大全,个人网站如何注销?  Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程  如何快速生成专业多端适配建站电话?  高端建站如何打造兼具美学与转化的品牌官网?  使用豆包 AI 辅助进行简单网页 HTML 结构设计  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  php增删改查怎么学_零基础入门php数据库操作必知基础【教程】  bing浏览器学术搜索入口_bing学术文献检索地址  Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】  如何快速搭建高效服务器建站系统?  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  音乐网站服务器如何优化API响应速度?  郑州企业网站制作公司,郑州招聘网站有哪些?  深圳网站制作培训,深圳哪些招聘网站比较好?  如何注册花生壳免费域名并搭建个人网站?  Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置  Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】  简单实现Android验证码  北京专业网站制作设计师招聘,北京白云观官方网站?  如何在建站主机中优化服务器配置?  详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南  Laravel如何配置Horizon来管理队列?(安装和使用)  Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置  中山网站制作网页,中山新生登记系统登记流程?