>백엔드 개발 >PHP 튜토리얼 >PHP 배열 순회에 대한 차이점(array_diff 적용 예)

PHP 배열 순회에 대한 차이점(array_diff 적용 예)

WBOY
WBOY원래의
2016-07-25 08:58:38908검색
  1. function array_diff($array_1, $array_2) {

  2. $diff = array();< ;/p>
  3. foreach ($array_1 as $k => $v1) {

  4. $flag = false;
  5. foreach ($array_2 as $v2) {
  6. if ( $flag = ($v1 == $v2)) {
  7. break;
  8. }
  9. }

  10. if (!$flag) {

  11. $diff [$k] = $v1;
  12. }
  13. }

  14. return $diff;

  15. }
  16. ?>
코드 복사

위 코드의 구현은 다소 무리가 있습니다. 그래서 나는 그것을 다시 생각하고 알고리즘을 최적화했습니다. 두 번째 함수는 다음과 같습니다.

  1. function array_diff($array_1, $array_2) {

  2. foreach($array_1 as $key => $item) {
  3. if (in_array($item, $array_2, true)) {
  4. unset($array_1[$key]);
  5. }
  6. }
  7. return $array_1;

  8. }
  9. ?>
코드 복사

이번에는 원래 array_diff 함수만큼 빠릅니다. 하지만 더 최적화된 방법이 있을까요? PHP는 다음과 같이 작성할 수 있다는 것을 알았습니다.

  1. function array_diff($array_1, $array_2) {

  2. $array_2 = array_flip( $array_2);
  3. foreach ($array_1 as $key => $item) {
  4. if (isset($array_2[$item])) {
  5. unset($array_1[$key]);
  6. }
  7. }

  8. return $array_1;

  9. }
  10. ?>
코드 복사

이 함수의 효율성은 놀랍습니다. 원래 array_diff 함수보다 훨씬 빠릅니다. 이유를 조사한 결과 다음과 같은 설명을 찾았습니다.

키가 HASH로 정리되어 있어서 검색이 매우 빠릅니다. 값은 Key로만 구성되고 저장되며 인덱스 자체는 없으며 각 검색이 순회됩니다. 요약 이는 PHP 언어의 약간의 트릭이지만 배열 값을 순회하고 비교할 때 값을 비교해야 하는 경우 키를 사용하여 이를 반전하는 것이 실제로 일반적인 값 대 값 비교보다 훨씬 효율적입니다.

예를 들어 위의 함수 2는 in_array 함수를 호출해야 하며 함수 내에 있는지 확인하기 위해 반복해야 하며, 함수 3은 키가 배열에 존재하는지 여부만 확인합니다. 배열 키와 값의 다양한 조직적 인덱싱 방법과 결합하면 효율성이 상상 이상으로 높다는 것은 매우 이해할 수 있습니다.

전체 코드는 다음과 같습니다.

  1. function microtime_float() {
  2. list($usec, $sec) = 폭발 (" ", microtime());
  3. return ((float)$usec (float)$sec);
  4. }

  5. function array_diff2($array_1, $array_2 ) {

  6. $diff = array();

  7. foreach ($array_1 as $k => $v1) {

  8. $flag = false;
  9. foreach ($array_2를 $v2로) {
  10. if ($flag = ($v1 == $v2)) {
  11. break;
  12. }
  13. }

  14. $diff[$k] = $v1;
  15. }
  16. }

  17. return $diff;

  18. }< ;/p>
  19. function array_diff3($array_1, $array_2) {
  20. foreach ($array_1 as $key => $item) {
  21. if (in_array($item) , $array_2, true)) {
  22. unset($array_1[$key]);
  23. }
  24. }

  25. return $array_1;

  26. }< ;/p>
  27. function array_diff4($array_1, $array_2) {
  28. $array_2 = array_flip($array_2);
  29. foreach ($array_1 as $key => $ item) {
  30. if (isset($array_2[$item])) {
  31. unset($array_1[$key]);
  32. }
  33. }

  34. < p>return $array_1;
  35. }

  36. //////////////////////////// / //

  37. for($i = 0, $ary_1 = array(); $i < 5000; $i ) {

  38. $ary_1[] = rand(100 , 999);
  39. }

  40. for($i = 0, $ary_2 = array(); $i < 5000; $i ) {

  41. $ary_2[ ] = rand(100, 999);
  42. }

  43. header("콘텐츠 유형: text/plain;charset=utf-8");

  44. $time_start = microtime_float();

  45. array_diff($ary_1, $ary_2);
  46. echo "array_diff 함수가 실행됩니다." (microtime_float() - $time_start) " 초 n";< ; /p>
  47. $time_start = microtime_float();

  48. array_diff2($ary_1, $ary_2);
  49. echo "array_diff2 함수가 실행됩니다." (microtime_float() - $time_start) " 초 n";

  50. $time_start = microtime_float();

  51. array_diff3($ary_1, $ary_2);
  52. echo "array_diff3 함수가 실행됩니다." . (microtime_float() - $ time_start) . " 초 n";

  53. $time_start = microtime_float();

  54. array_diff4($ary_1, $ary_2);
  55. echo "array_diff4 함수가 실행됩니다." ( microtime_float() - $time_start) . " 초 n";
  56. ?>

코드 복사


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.