ホームページ >バックエンド開発 >PHPチュートリアル >順列と組み合わせのアルゴリズムに関する質問です。いくつかのアイデアから始めましょう。
順列と組み合わせのアルゴリズムの問題です。
私は中学校で 1 2 3 4 5 6 の順列と組み合わせで 720 個の異なる文字列を形成できることを学びました
。
ここでは大まかな実装方法を書いています。例は1~6です。
専門家にアドバイスをいただければ幸いです
$j=0;
for($i=123456;$i
$box=array();
$ge =$i%10;
if($ge>6 || $ge==0){
続行;
}
$box[]=$ge;
$shi = intval($i/10)%10;
if($shi>6 || $shi ==0){
続行;
}
$box[]=$shi;
$bai = intval($i/100)%10;
if($bai>6 || $bai ==0){
続行;
}
$box[]=$bai;
$qian = intval($i/1000)%10;
if($qian>6 || $qian ==0){
続行;
}
$box[]=$qian;
$wan = intval($i/10000)%10;
if($wan>6 || $wan ==0){
続行;
}
$box[]=$wan;
$shiwan = intval($i/100000);
if($shiwan>6 || $shiwan ==0){
続行;
}
$box[]=$shiwan;
//エコーカウント(array_unique($box));
//エコー '0c6dc11e160d3b678d68754cc175188a';
//var_dump(array_unique($box));
//エコー '0c6dc11e160d3b678d68754cc175188a';
if(count(array_unique($box))!=6){
続行;
}
if($j%10==0){
echo "df250b2156c434f3390392d09b1c9563";
}
$j++;
echo ' ',$i,' ';
}
echo "df250b2156c434f3390392d09b1c9563";
echo "合計{$j}";
-----解決策---------
$a = perm(array(1,2,3,4,5,6));<br /> echo count($a);<br /> //print_r($a);<br /> <br /> function perm($list, $k=0, $m=0) { <br /> if(! $m) $m = count($list) - 1; <br /> $r = array(); <br /> if($k >= $m) { <br /> $r[] = join('', $list); <br /> }else { <br /> for($i = $k; $i <= $m; $i++) { <br /> list($list[$k], $list[$i]) = array($list[$i], $list[$k]);<br /> $r = array_merge($r, perm($list, $k + 1, $m)); <br /> list($list[$k], $list[$i]) = array($list[$i], $list[$k]);<br /> }<br /> }<br /> return $r;<br /> }720