php全排列

字符串全排列(递归)

function permutationStr($str, $tmp = '')
{
	$length = strlen($str);
	if($length <= 1){
		echo $str.$tmp."\n";
	}else{
		for ($i=0; $i < $length; $i++) { 
		/*	$flag = false;//去除重复
            for($j=0; $j < $i; $j++){
                if($str[$i] == $str[$j]){
                    $flag = true;
                    break;
                }
            }
            if($flag){
                continue;
            }*/
			permutationStr(substr($str, 0, $i).substr($str, $i+1, $length-$i-1), $tmp.$str[$i]);
		}
	}
}

数组全排列(递归)

function permutation($arr, $tmp = [])
{
	$length = count($arr);
	if($length <= 1){
		echo implode(' ', array_merge($arr, $tmp))."\n";
	}else{
		for ($i=0; $i < $length; $i++) {
			permutation(array_merge(array_slice($arr, 0, $i), array_slice($arr, $i+1, $length-$i-1)), array_merge($tmp, [$arr[$i]]));
		}
	}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值