ホームページ  >  記事  >  バックエンド開発  >  配列の完全な配置と要素のすべての組み合わせを見つけるための PHP メソッド

配列の完全な配置と要素のすべての組み合わせを見つけるための PHP メソッド

高洛峰
高洛峰オリジナル
2017-01-14 13:32:561452ブラウズ

この記事の例では、PHP で配列の完全な配置と要素のすべての組み合わせを見つける方法を説明します。参考のために皆さんと共有してください。詳細は次のとおりです:

<?php
$source = array(&#39;pll&#39;,&#39;我&#39;,&#39;爱&#39;,&#39;你&#39;,&#39;嘿&#39;);
sort($source); //保证初始数组是有序的
$last = count($source) - 1; //$source尾部元素下标
$x = $last;
$count = 1; //组合个数统计
echo implode(&#39;,&#39;, $source), "<br>"; //输出第一种组合
while (true) {
  $y = $x--; //相邻的两个元素
  if ($source[$x] < $source[$y]) { //如果前一个元素的值小于后一个元素的值
    $z = $last;
    while ($source[$x] > $source[$z]) { //从尾部开始,找到第一个大于 $x 元素的值
      $z--;
    }
    /* 交换 $x 和 $z 元素的值 */
    list($source[$x], $source[$z]) = array($source[$z], $source[$x]);
    /* 将 $y 之后的元素全部逆向排列 */
    for ($i = $last; $i > $y; $i--, $y++) {
      list($source[$i], $source[$y]) = array($source[$y], $source[$i]);
    }
    echo implode(&#39;,&#39;, $source), "<br>"; //输出组合
    $x = $last;
    $count++;
  }
  if ($x == 0) { //全部组合完毕
    break;
  }
}
echo &#39;Total: &#39;, $count, "\n";
?>

この記事が PHP プログラミングの皆さんに役立つことを願っています。

配列の完全な配置と要素のすべての組み合わせを見つけるためのその他の PHP メソッドについては、PHP 中国語 Web サイトに注目してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。