• 数组去重


    1.使用array_unique方法进行去重

    对数组元素进行去重,我们一般会使用array_unique方法,使用这个方法可以把数组中的元素去重。

     

    1

    2

    3

    4

    5

    6

    <?php

    $arr = array(1,1,2,3,3,3,4,4,5,6,6,7,8,8,9,9,9);

    $arr = array_unique($arr);

    $arr = array_values($arr);

    print_r($arr);

    ?>

    输出:

     

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    Array

    (

      [0] => 1

      [1] => 2

      [2] => 3

      [3] => 4

      [4] => 5

      [5] => 6

      [6] => 7

      [7] => 8

      [8] => 9

    )

    去重后,键值会不按顺序,可以使用array_values把键值重新排序。

    2.使用array_unique方法去重效率

     

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    27

    28

    29

    30

    31

    32

    33

    34

    35

    36

    37

    38

    39

    40

    <?php

    $arr = array();

     

    // 创建100000个随机元素的数组

    for($i=0; $i<100000; $i++){

      $arr[] = mt_rand(1,99);

    }

     

    // 记录开始时间

    $starttime = getMicrotime();

     

    // 去重

    $arr = array_unique($arr);

     

    // 记录结束时间

    $endtime = getMicrotime();

     

    $arr = array_values($arr);

     

    echo 'unique count:'.count($arr).'<br>';

    echo 'run time:'.(float)(($endtime-$starttime)*1000).'ms<br>';

    echo 'use memory:'.getUseMemory();

     

    /**

     * 获取使用内存

     * @return float

     */

    function getUseMemory(){

      $use_memory = round(memory_get_usage(true)/1024,2).'kb';

      return $use_memory;

    }

    /**

     * 获取microtime

     * @return float

     */

    function getMicrotime(){

      list($usec, $sec) = explode(' ', microtime());

      return (float)$usec + (float)$sec;

    }

    ?>

    unique count:99 
    run time:653.39303016663ms 
    use memory:5120kb

    使用array_unique方法去重,运行时间需要约650ms,内存占用约5m 

    3.更快的数组去重方法

    PHP有一个键值互换的方法array_flip,我们可以使用这个方法去重,因为键值互换,原来重复的值会变为相同的键。

    然后再进行一次键值互换,把键和值换回来则可以完成去重。

     

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    27

    28

    29

    30

    31

    32

    33

    34

    35

    36

    37

    38

    39

    40

    41

    <?php

    $arr = array();

     

    // 创建100000个随机元素的数组

    for($i=0; $i<100000; $i++){

      $arr[] = mt_rand(1,99);

    }

     

    // 记录开始时间

    $starttime = getMicrotime();

     

    // 使用键值互换去重

    $arr = array_flip($arr);

    $arr = array_flip($arr);

     

    // 记录结束时间

    $endtime = getMicrotime();

     

    $arr = array_values($arr);

     

    echo 'unique count:'.count($arr).'<br>';

    echo 'run time:'.(float)(($endtime-$starttime)*1000).'ms<br>';

    echo 'use memory:'.getUseMemory();

     

    /**

     * 获取使用内存

     * @return float

     */

    function getUseMemory(){

      $use_memory = round(memory_get_usage(true)/1024,2).'kb';

      return $use_memory;

    }

    /**

     * 获取microtime

     * @return float

     */

    function getMicrotime(){

      list($usec, $sec) = explode(' ', microtime());

      return (float)$usec + (float)$sec;

    }

    ?>

    unique count:99 
    run time:12.840032577515ms 
    use memory:768kb

    使用array_flip方法去重,运行时间需要约18ms,内存占用约2m

    因此使用array_flip方法去重比使用array_unique方法运行时间减少98%,内存占用减少4/5;

  • 相关阅读:
    RTSP/RTMP/GB28181协议视频监控平台搭建之国网B接口协议介绍
    如何判断视频流媒体播放器EasyPlayerRTSPWin的磁盘空间是否满足剩余的要求?
    H.265编码全面应用于TSINGSEE青犀视频全产品链,让视频更清晰!
    视频流媒体播放器EasyPlayerRTSP原始录像文件被新录像文件覆盖是什么原因?
    RTSP/RTMP/GB28181协议TSINGSEE青犀视频云服务搭建H265开发环境无法启动是什么原因?
    H265流媒体播放器EasyPlayer.JS在web开发项目中引用报“webAssembly instantiate”错误解决方案
    使用Opengl实现天空盒
    手机探索者开发实录—数据打包
    游戏开发中的设计模式之一-Strategy模式
    手机探索者开发实录—rndis/usbnet
  • 原文地址:https://www.cnblogs.com/wen-zi/p/10225162.html
Copyright © 2020-2023  润新知