当前位置: 首页 > news >正文

20、PHP字符串的排列(含源码)

题目: PHP字符串的排列?

描述:
输入一个字符串,按字典序打印出该字符串中字符的所有排列。
例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
输入描述:
输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。

<?phpfunction Permutation($str)
{if($str==""){return [];}$arr = str_split($str);sort($arr);$r = [];per($arr, $r, '');return $r;
}function swap(&$a, &$b){$tmp = $a;$a = $b;$b = $tmp;
}function per($arr, &$r, $str){$len = count($arr);if($len == 1){$r[] = $str.$arr[0];return;}for($i=0;$i<$len;$i++){if($i!=0 && $arr[$i] == $arr[0]){continue;}swap($arr[$i],$arr[0]);per(array_slice($arr,1), $r, $str.$arr[0]);}
}
http://www.lryc.cn/news/389662.html

相关文章:

  • Linux 标准IO的fopen和fclose
  • 一个计算密集小程序在不同CPU下的表现
  • 圈子系统搭建教程,以及圈子系统的功能特点,圈子系统,允许二开,免费源码,APP小程序H5
  • 递归算法练习
  • WebDriver 类的常用属性和方法
  • 基于x86+FPGA+AI轴承缺陷视觉检测系统,摇枕弹簧智能检测系统
  • 短剧小程序系统cps分销开发搭建
  • 代理IP的10大误区:区分事实与虚构
  • 数组-长度最小的子数组
  • 深度学习之交叉验证
  • 使用 Python 五年后,我发现学 python 必看这三本书!少走一半弯路
  • React@16.x(45)路由v5.x(10)源码(2)- history
  • grpc学习golang版( 八、双向流示例 )
  • SpringBoot学习05-[SpringBoot的嵌入式Servlet容器]
  • 查看Oracle是哪个Oracle_home 下启动的
  • 重温react-06(初识函数组件和快速生成格式的插件使用方式)
  • 【高考志愿】仪器科学与技术
  • Elasticsearch的Mapping
  • 【vocabulary in use (elementary)】6 Health and Illness
  • 探囊取物之多形式注册页面(基于BootStrap4)
  • 【C++进阶学习】第五弹——二叉搜索树——二叉树进阶及set和map的铺垫
  • 【RabbitMQ实战】Springboot 整合RabbitMQ组件,多种编码示例,带你实践 看完这一篇就够了
  • 【你也能从零基础学会网站开发】理解DBMS数据库管理系统架构,从用户到数据到底经历了什么
  • Vue.js 中的API接口封装实战与详解
  • 职场内卷、不稳定、没前景……怎么破?
  • LeetCode 算法:将有序数组转换为二叉搜索树 c++
  • 智慧公厕系统改变了人们对服务区公厕的看法
  • 终极指南:RNNS、Transformers 和 Diffusion 模型
  • WPF UI 3D 基本概念 点线三角面 相机对象 材质对象与贴图 3D地球 光源 变形处理 动作交互 辅助交互插件 系列三
  • 分子AI预测赛Task2笔记