ホームページ >バックエンド開発 >PHPの問題 >PHP は 10 個の非反復乱数を生成します

PHP は 10 個の非反復乱数を生成します

王林
王林オリジナル
2019-09-30 11:54:437574ブラウズ

PHP は 10 個の非反復乱数を生成します

質問:

投票対象作品は 25 件あります。1 回の投票で 16 作品を選択する必要があります。選択できる作品は 1 つだけです1票に1回。プログラマーが以前にミスを犯し、投票をデータベースに保存するのを忘れたため、200 人のユーザーによって生成された投票シーケンスは空でした。では、このギャップをどのように埋めるのでしょうか?

これを埋めるには、1 ~ 25 の非繰り返しの乱数を 16 個生成する必要があります。具体的に機能をどう設計するか?乱数を配列に格納し、配列内の重複する値を削除して、一定数の非反復乱数を生成します。

プログラムは次のとおりです:

<?php
/*
* array unique_rand( int $min, int $max, int $num )
* 生成一定数量的不重复随机数
* $min 和 $max: 指定随机数的范围
* $num: 指定生成数量
*/
function unique_rand($min, $max, $num) {
  $count = 0;
  $return = array();
  while ($count < $num) {
      $return[] = mt_rand($min, $max);
      $return = array_flip(array_flip($return));
      $count = count($return);
  }
  shuffle($return);
  return $return;
}
$arr = unique_rand(1, 25, 16);
sort($arr);
$result = &#39;&#39;;
for($i=0; $i < count($arr);$i++)
{
  $result .= $arr[$i].&#39;,&#39;;
}
$result = substr($result, 0, -1);
echo $result;
?>

実行結果は次のとおりです:

2,3,4,6,7,8,9,10,11,12,13,16,20,21,22,24

追加の手順:

1. mt_rand() 関数は乱数を生成するために使用されます。この関数は、rand() よりも平均して 4 倍の速度で乱数を生成します。

2. 配列から重複した値を削除する場合は、array_flip()関数を使って配列のキーと値を2回交換する「フリップ方式」が使用されます。このアプローチは、array_unique() 関数を使用するよりもはるかに高速です。
3. 配列を返す前に、まず shuffle() を使用して新しいキー名を配列に割り当て、キー名が 0 ~ n の連続番号であることを確認します。この手順を実行しないと、重複した値を削除するときにキー名が不連続になり、トラバーサルに問題が発生する可能性があります。

推奨チュートリアル: PHP ビデオ チュートリアル

以上がPHP は 10 個の非反復乱数を生成しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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