zoukankan      html  css  js  c++  java
  • 从一个数组中随机的取出若干个不同的数

    /*
     * 此程序是从一个不反复的数组中随机的取出若干个不同的元素
     * 难点是防止在取数的时候出现已经取到过的情况(特别是取到最后),须要尽可能的减少碰撞
     */
    //第一种算法。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));
    





  • 相关阅读:
    Android平板电脑开发实战详解和典型案例
    UG NX10.0技术大全(不附光盘)
    SolidWorks 2018中文版机械设计应用大全
    1192.回文字符串
    1193.矩阵转置
    1195.最长&最短文本
    1194.八进制
    1196.成绩排序
    1197.奇偶检验
    1199.找位置
  • 原文地址:https://www.cnblogs.com/lcchuguo/p/5203769.html
Copyright © 2011-2022 走看看