群里有人问,有个数组五个元素 分为1到5 现在要求 循环找出3元素的索引,怎么做性能才是最高。
我不知道哪个性能最高,但是我想提出可以用多种方式进行查找,然后进行比较选择。
我想,最简单最基础的 应该是循环,循环到它,那就是它。当然也可以用PHP提供的数组查找 array_search。这都是能想得到的,那么我想说的是,剑走偏锋,老铁是否尝试过 键值反转进行查找呢?
array_flip键值反转,能够将你需要的键变值,值变键,然后取数组下标,即可得到这个位置。
代码如下:
<?php $array=array(2,3,4,1,5); //找到3所处的位置 $find=3; //第一种方式 循环解决 此举类似于 for while等循环 function find_by_foreach($array,$find) { foreach ($array as $key => $v) { if($v==$find) { return $key; } } } //第二种方式 利用数组查找 找到所需要元素的索引位置 function find_by_array_search($array,$find) { return array_search($find,$array); } //第三种方式 键值反转 通过值查找键 function find_by_array_flip($array,$find) { $array=array_flip($array); return $array[$find]; } var_dump(find_by_foreach($array,$find)); var_dump(find_by_array_search($array,$find)); var_dump(find_by_array_flip($array,$find));
效果如图:
好,我们再考虑一个问题,刚刚我们都在用数组的思维进行解决问题,如果说,这个数组不想被循环,或者放弃数组的思路又该如何解决呢?
很自然,我们可以想到依靠字符串。那么字符串的函数也是非常多的,PHP在这方面的功劳是不遗余力。
代码如下:
<?php //第四种方式 字符串查找 function find_by_string($array,$find) { $string=implode($array); return strpos($string,$find.""); }
效果如图:
针对本题而言,字符串查找是可行的,但是如果换一个场景,数组中出现了重复或者要查找的元素,不能出现完整匹配的情况的时候,这个查找就是失败的,请思考一下这是为什么。