php 字符串所有组合,如何在PHP中生成字符串的所有排列?

b749d95ce072be43531548f3c861ea80.png

翻过高山走不出你

我会将所有字符放在一个数组中,并编写一个递归函数,它将“删除”所有剩余的字符。如果数组为空,则为引用传递的数组。<?php

$input = "hey";function string_getpermutations($prefix, $characters, &$permutations){

    if (count($characters) == 1)

        $permutations[] = $prefix . array_pop($characters);

    else

    {

        for ($i = 0; $i 

        {

            $tmp = $characters;

            unset($tmp[$i]);

            string_getpermutations($prefix . $characters[$i], array_values($tmp), $permutations);

        }

    }}$characters = array();for ($i = 0; $i 

    $characters[] = $input[$i];$permutations = array();print_r($characters);string_getpermutations("", $characters, $permutations);print_r($permutations);打印出来:Array(

    [0] => h    [1] => e    [2] => y)Array(

    [0] => hey    [1] => hye    [2] => ehy    [3] => eyh    [4] => yhe    [5] => yeh)啊,是的,组合=顺序无关紧要。排列=顺序确实很重要。所以,嘿,是的,所有的组合都是一样的,但是提到了3个独立的排列。注意物品的规模上升得非常快。它叫做阶乘,写得像6!= 6 * 5 * 4 * 3 * 2 * 1 = 720项(6字符串)。一个10个字符的字符串将是10!= 3628800已经排列,这是一个非常大的数组。在这个例子中它是3!= 3 * 2 * 1 = 6。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值