为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

如何在PHP中生成字符串的所有排列?我需要一个算法,它返回一个字符串中所有字符的所有可能组合。我试过了:$langd = strlen($input);  for($i = 0;$i < $langd; $i++){      $tempStrang = NULL;      $tempStrang .= substr($input, $i, 1);   for($j = $i+1, $k=0; $k < $langd; $k++, $j++){    if($j > $langd) $j = 0;    $tempStrang .= substr($input, $j, 1);  }  $myarray[] = $tempStrang;}但是,它只返回与字符串长度相同的数量组合。说$input = "hey",结果将是:hey, hye, eyh, ehy, yhe, yeh。
查看完整描述

3 回答

?
梵蒂冈之花

TA贡献1900条经验 获得超5个赞

您可以使用基于反向跟踪的方法系统地生成所有排列:

// function to generate and print all N! permutations of $str. (N = strlen($str)).function permute($str,$i,$n) {
   if ($i == $n)
       print "$str\n";
   else {
        for ($j = $i; $j < $n; $j++) {
          swap($str,$i,$j);
          permute($str, $i+1, $n);
          swap($str,$i,$j); // backtrack.
       }
   }}// function to swap the char at pos $i and $j of $str.function swap(&$str,$i,$j) {
    $temp = $str[$i];
    $str[$i] = $str[$j];
    $str[$j] = $temp;}   $str = "hey";permute($str,0,strlen($str)); // call the function.

输出:

#php a.phphey
hye
ehy
eyh
yeh
yhe


查看完整回答
反对 回复 2019-08-02
  • 3 回答
  • 0 关注
  • 821 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信