이 글은 PHP에서 카운팅 정렬을 구현하는 방법에 대한 코드를 소개합니다. 필요한 친구들이 참고할 수 있기를 바랍니다.
/** * 计数排序: 桶排序的一种 */ $arr = [5,69,4,32,14,8,74,95,23,56,41,5,31,63]; // include 'data.php'; $length = count($arr); $maxValue = $arr[0]; // 找出数组中的最大值 for ($i=1; $i < $length; $i++) { if ($arr[$i] > $maxValue) { $maxValue = $arr[$i]; } } /** * 定长数组, 键会自动排序, PHP数组是hash表的实现, * 如果这里用普通的数组, 键不会自动排序, 不存在的键也不会自动填充null */ $frequency = new SplFixedArray($maxValue + 1); /** * 统计arr中, 值出现的频次 */ for ($i=0; $i < $length; $i++) { if(empty($frequency[$arr[$i]])) $frequency[$arr[$i]] = 0; $frequency[$arr[$i]] += 1; } // 清空$arr $arr = []; // 遍历frequency, 如果其元素有值, 那么将键push到arr中 for ($i=0; $i < count($frequency); $i++) { if (!empty($frequency[$i])) { for ($j=0; $j < $frequency[$i]; $j++) { $arr[] = $i; } } } print_r($arr);
추천 관련 기사:
# 🎜🎜#Nginx숨겨진 항목 파일 index.php 구성 방법(코드)
위 내용은 PHP에서 계산 정렬 코드를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!