RSS订阅·收藏本站·网站地图·网页代码测试·在线小游戏
行业资讯IT动态手机数码电子商务搜索引擎网络游戏
行业评论门户动态收购融资站长资讯通信要闻传媒
编程语言PHPASPc++Html/CssMySqlasp.netVisual Basic
电脑技术入门实用技术办公软件网络安全QQ专题IT必备书
站长教学频道
网站模板下载

您当前的位置:学院首页>编程语言>PHP入门>浏览文章

PHP数组交集的优化

时间:2011-02-19 来源:火丁笔记 编辑:itxyz.net 点击: 次 字体:[ ] 关注站长微博

假设我们正在运营一个手机相关的网站,用户可以通过指定若干参数(如操作系统,屏幕分辨率,摄像头像素等等)来筛选自己想要的手机。不过由于手机的参数多,且不同的手机其参数差异大,所以参数表结构通常是纵表(一个参数是一行),而不是横表(一个参数是一列),此时使用若干参数来取结果,通常就是把每个单独参数来取结果,再一起取交集。

@ itxyz.net

假定每个参数会包含一千个左右的唯一结果(id int),以此为前提来模拟生成一些数据:

@ itxyz.net

<?php

$rand = function() {
    $result = array();

    for ($i = 0; $i < 1000; null) {
        $value = mt_rand(1, 10000);

        if (!isset($result[$value])) {
            $result[$value] = null;
            $i++;
        } @ itxyz.net
    }

    return array_keys($result);
};

$param_a = $rand();
$param_b = $rand();

?>

@ itxyz.net

@ itxyz.net

注意:如果测试数据集过小的话,结论可能会出现不一致,先来看看通过PHP内置方法array_intersect实现的性能:

@ itxyz.net

<?php

$time = microtime(true);

$result = array_intersect($param_a, $param_b);

$time = microtime(true) - $time;

echo "array_intersect: {$time}\n";

?>

@ itxyz.net

@ itxyz.net

顶一下
(1)
100%
踩一下
(0)
0%
上一篇:在centos5上一行命令安装virtualmin/Webmin
下一篇:没有了
Tags:优化 PHP数组 交集 
责任编辑:itxyz.net
  • 相关文章
    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    评价:
    验证码: 点击我更换图片

    搜索教程

    赞助商链接

    推荐内容

    推荐图集

    热点内容