/* * 此程序是從一個不重復的數組中隨機的取出若干個不同的元素 * 難點是防止在取數的時候出現已經取到過的情況(特別是取到最後),需要盡可能的降低碰撞 */ //第一種算法,CSDN上別人的想法 /* $num = 0; $array = array(1, 2, 3, 4, 5, 6, 7, 8, 9); $arr = array(); $g = 5; $tag = true; while ($tag) { $count = count($array); $t = rand(0, 1); if ($t == 1) { $arr[] = $array[$num]; unset($array[$num]); } $num ++; if (count($arr) == $g) { $tag = false; } if ($num == $count) { $num = 0; //循環 } } var_dump($arr); */ //第二種算法,自己想的。 //可以在每次取出數據之後將該數據和最後沒有獲取的數據替換,然後再去沒有取得的數據中隨機獲取值 function swap(&$a, &$b) { $temp = $b; $b = $a; $a = $temp; } $result = array(); $src = array(); for($i = 0 ; $i < 40 ; $i++) { $src[] = $i + 1; } $arr_len = count($src); $count = 20; $index = 0; while($index < $count) { $random = rand(0, $arr_len - $index - 1); $result[] = $src[$random]; swap($src[$random] , $src[$arr_len - $index - 1]); $index += 1; } print_r(json_encode($result)); print_r(json_encode($src));