【phpstudy】php 查找数组值程序

更新时间:2017-10-28    来源:php函数    手机版     字体:

【www.bbyears.com--php函数】

查找一个元素是否在数组中,一共有上面三种做法:

in_array  "函数在数组中搜索给定的值。in_array(value,array,type)type 可选。如果设置该参数为 true,则检查搜索的数据与数组的值的类型是否相同。

array_key_exists "array_key_exists() 函数判断某个数组中是否存在指定的 key,如果该 key 存在,则返回 true,否则返回 false。array_key_exists(key,array)

Example #1 array_key_exists() 例子

 代码如下

$search_array = array("first" => 1, "second" => 4);
if (array_key_exists("first", $search_array)) {
    echo "The "first" element is in the array";
}
?>

Example #2 array_key_exists() 与 isset() 的对比

isset() 对于数组中为 NULL 的值不会返回 TRUE,而 array_key_exists() 会。

 代码如下

$search_array = array("first" => null, "second" => 4);

// returns false
isset($search_array["first"]);

// returns true
array_key_exists("first", $search_array);
?>

mixed array_search ( mixed $needle, array $haystack [, bool $strict] )
第一个参数是需要查找的值,第二个参数是数组,最后一个参数是指查找的时候是否检查数据类型是否相同。

 代码如下

$a=array("a"=>"Dog","b"=>"Cat","c"=>"Horse");
echo array_search("Dog",$a);
?>

$a=array("a"=>"5","b"=>5,"c"=>"5");
echo array_search(5,$a,true);
?>
上述代码将输出下面的结果:
b

从这里来看,在数据量不大的时候,比如小于1000,查找用哪一种都行,都不会成为瓶颈;
当数据量比较大的时候,用array_key_exists比较合适。
当然这里array_key_exists占用的内存比较大,经测算
数组结构是: array(1, 2, 3, ..)和 array(1 => true, 2 => false, ..)
他们内存使用比值为1:2;

注意:array_key_exist,要比in_array效率高十几甚至几十倍

一个简单的算法

假设数组有1000个元素,键值为小于1000000的无序的正整数,且不连续,如下

$arr = array(1 => "sadas", 20 => "aasd", 5002 => "fghfg", 190023 => "rty", 248 => "kj", 76 => "sddd" ,...);

现在要获取数组$arr中键的值大于500小于600的元素,不用foreach完全循环一遍的话是否有更高效的算法?

解答

 代码如下


$result = array();
for($i = 501; $i < 600; $i++) {
    if(!isset($arr[$i])) continue;
    $result[] = $arr[$i];
}

本文来源:http://www.bbyears.com/jiaocheng/36631.html