PHP 개발에서 배열은 매우 일반적으로 사용되는 데이터 유형입니다. 우리는 일반적으로 일련의 데이터를 저장하기 위해 배열을 사용합니다. 때로는 서로 다른 요소가 배열에 나타나는 횟수를 세는 것과 같이 배열에서 서로 다른 값을 계산해야 할 때가 있습니다. 이 기사에서는 PHP를 사용하여 배열의 다양한 값을 계산하는 방법을 보여줍니다.
PHP에는 배열에서 각 값의 발생 횟수를 계산하는 데 사용할 수 있는 내장 함수 array_count_values
가 있습니다. 이 함수의 프로토타입은 다음과 같습니다. array_count_values
,可以用来统计数组中各个值出现的次数。该函数的原型如下:
array_count_values(array $array): array
该函数需要一个数组作为参数,并返回一个关联数组,其中键是原始数组中的不同值,值是该值在原数组中出现的次数。例如:
$array = array(1, 1, 2, 3, 3, 3); $count = array_count_values($array); print_r($count);
输出:
Array( [1] => 2 [2] => 1 [3] => 3 )
这里原数组是 [1, 1, 2, 3, 3, 3]
,函数返回的关联数组中,键 1
在原数组中出现了 2 次,键 2
在原数组中出现了 1 次,键 3
在原数组中出现了 3 次。
需要注意的是,该函数只对索引数组和关联数组有效,对于其他类型的数组,会返回一个空数组。
除了使用 array_count_values
函数,我们也可以自己编写一个函数来完成类似的功能。以下是一个示例函数:
function array_count_unique(array $array): array { $counts = array(); foreach ($array as $value) { if (isset($counts[$value])) { $counts[$value]++; } else { $counts[$value] = 1; } } return $counts; }
该函数接受一个数组,返回一个关联数组,其中键是原始数组中的不同值,值是该值在原数组中出现的次数。具体实现思路是通过遍历原数组,统计每个值出现的次数,然后以该值为键,出现次数为值,构造结果数组。
我们可以使用以下代码测试该函数:
$array = array(1, 1, 2, 3, 3, 3); $count = array_count_unique($array); print_r($count);
输出:
Array( [1] => 2 [2] => 1 [3] => 3 )
与 array_count_values
函数的结果相同。
需要注意的是,该函数只对索引数组和关联数组有效,对于其他类型的数组,会返回一个空数组。
虽然使用 PHP 内置的 array_count_values
函数和自定义函数都可以完成统计数组中不同值的功能,但它们在性能上可能会有所不同。我们可以通过使用 microtime
函数来测试两种方法的性能。
以下是使用 array_count_values
函数的测试示例:
$array = range(1, 10000); shuffle($array); $start = microtime(true); $count = array_count_values($array); $end = microtime(true); echo 'array_count_values: ' . ($end - $start) . ' seconds';
以下是使用自定义函数的测试示例:
$array = range(1, 10000); shuffle($array); $start = microtime(true); $count = array_count_unique($array); $end = microtime(true); echo 'array_count_unique: ' . ($end - $start) . ' seconds';
两个测试示例的输入相同,都是一个长度为 10000 的随机数组,输出每个方法执行的时间。我们可以多次运行这两个代码片段,比较两个函数的平均运行时间。
在本人测试的环境中,两个方法的时间差异不太明显,通常 array_count_unique
函数略快于 array_count_values
函数,但两者的差异不大。因此,在实际应用中,可以根据需要选择适当的方法。
总结
本文介绍了如何使用 PHP 统计数组中不同的值。我们可以使用 PHP 内置的 array_count_values
rrreee
[1, 1, 2, 3, 3, 3]
이고 함수에서 반환된 연관 배열에서 키는 다음과 같습니다. 1
은 원래 배열에 2번 나타나고, 2
키는 원래 배열에 1번 나타나고, 3
키는 3번 나타납니다. 원래 배열. 🎜🎜이 함수는 인덱스 배열 및 연관 배열에만 유효합니다. 다른 유형의 배열의 경우 빈 배열이 반환됩니다. 🎜array_count_values
함수를 사용하는 것 외에도 함수를 직접 작성하여 유사한 함수를 완성할 수도 있습니다. 다음은 함수 예입니다. 🎜rrreee🎜 이 함수는 배열을 가져와서 키가 원래 배열의 고유한 값이고 값이 원래 배열에 값이 나타나는 횟수인 연관 배열을 반환합니다. 구체적인 구현 아이디어는 원래 배열을 순회하고 각 값의 발생 횟수를 계산한 다음 해당 값을 키로 사용하고 발생 횟수를 값으로 사용하여 결과 배열을 구성하는 것입니다. 🎜🎜다음 코드를 사용하여 이 함수를 테스트할 수 있습니다. 🎜rrreee🎜출력: 🎜rrreee🎜 array_count_values
함수와 동일한 결과입니다. 🎜🎜이 함수는 인덱스 배열 및 연관 배열에만 유효합니다. 다른 유형의 배열의 경우 빈 배열이 반환됩니다. 🎜array_count_values
함수와 사용자 정의 함수를 사용하면 배열의 다양한 값을 계산하는 기능을 완성할 수 있지만, 성능 측면에서 효율적이지 않을 수 있습니다. microtime
함수를 사용하여 두 방법의 성능을 테스트할 수 있습니다. 🎜🎜다음은 array_count_values
함수를 사용한 테스트 예시입니다. 🎜rrreee🎜다음은 맞춤 함수를 사용한 테스트 예시입니다. 🎜rrreee🎜두 테스트 예시의 입력은 동일합니다. 각 메소드의 실행 시간을 출력하는 길이 10000 배열의 임의 문자열입니다. 이 두 코드 조각을 여러 번 실행하고 두 함수의 평균 실행 시간을 비교할 수 있습니다. 🎜🎜제가 테스트한 환경에서는 두 메서드의 시간 차이가 명확하지 않습니다. 일반적으로 array_count_unique
함수가 array_count_values
함수보다 약간 빠르지만, 두 개는 크지 않습니다. 따라서 실제 적용에서는 필요에 따라 적절한 방법을 선택할 수 있습니다. 🎜🎜요약🎜🎜이 글에서는 PHP를 사용하여 배열의 다양한 값을 계산하는 방법을 소개합니다. PHP에 내장된 array_count_values
함수를 사용하거나 직접 함수를 작성할 수 있습니다. 두 방법 모두 유사한 기능을 수행하지만 성능은 약간 다릅니다. 실제 적용에서는 필요에 따라 적절한 방법을 선택할 수 있습니다. 🎜위 내용은 PHP 배열 통계 다른 값의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!