이 글은 PHP 빠른 정렬 문제에서 재귀 알고리즘과 반복 알고리즘의 구현을 소개합니다. 이제 이를 여러분과 공유합니다. 도움이 필요한 친구들은 이를 참조할 수 있습니다
구현 코드
https://github.com/ParrySMS/Exp/tree/master/ProLang/quickSort
재귀적 방법 quickSortRec.php
quickSortRec.php
<?php/** * Created by PhpStorm. * User: L * Date: 2018-4-13 * Time: 23:27 *//** 递归法快排序 * @param array $ar * @return array */function quickSortR(array $ar){ //判断数组长度 $size = sizeof($ar); if($size<=1){ return $ar; } //用两个数组分别接受比游标key小和比key大的数据 $left = array(); $right = array(); $key = $ar[0]; for($i =1;$i<$size;$i++){ if($ar[$i]<=$key){ $left[] = $ar[$i]; }else{ $right[] = $ar[$i]; } } //内部再进行排序 $left = quickSortR($left); $right = quickSortR($right); //最后合并 return array_merge($left,array($key),$right); }
迭代法 quickSortIter.php
<?php/** * Created by PhpStorm. * User: L * Date: 2018-4-14 * Time: 14:51 *//** 迭代法 * @param array $ar * @return array */function quickSortI(array $ar){ $stack = array($ar); $sort = array(); //判断数组长度 $size = sizeof($ar); if ($size <= 1) { return $ar; } //栈空即跳出循环 while ($stack) { $arr = array_pop($stack); if (count($arr) <= 1) { if (count($arr) == 1) { $sort[] = &$arr[0]; } continue; } $key = $arr[0]; $high = array(); $low = array(); //用两个数组分别接受比游标key小和比key大的数据 $_size = count($arr); for ($i = 1; $i < $_size; $i++) { if ($arr[$i] <= $key) { $high[] = &$arr[$i]; } else { $low[] = &$arr[$i]; } } if (!empty($low)) {//数据入站 array_push($stack, $low); } array_push($stack, array($arr[0])); if (!empty($high)) { array_push($stack, $high); } } return $sort; }
执行时间测试脚本 test.php
<?php/** * Created by PhpStorm. * User: L * Date: 2018-4-17 * Time: 23:45 */require "quickSortIter.php";require "quickSortRec.php"; define('SORT_TIMES', 100); define('SIZE', 1000);function rowTable(){ unset($row); $row = array(); for ($i = 0; $i < SORT_TIMES; $i++) { $row = getSortRow($row); } foreach ($row as $r) { print <<< TR <tr> <td>$r->iter</td> <td>$r->rec</td> </tr> TR; } }function getSortRow(array $row){ unset($ar); $ar = array(); for ($i = 0; $i < SIZE; $i++) { $ar[] = rand(0, SIZE*2); } $stime = microtime(true); $recAr = quickSortR($ar); $etime = microtime(true); $recTime = 1000 * ($etime - $stime);// echo"<br/>"; $stime = microtime(true); $iterAr = quickSortI($ar); $etime = microtime(true); $iterTime = 1000 * ($etime - $stime);// print_r($recAr);// echo "<br/>";// print_r($iterAr); $row[] = (object)["iter" => $iterTime, "rec" => $recTime]; return $row; }?><table border="1"> <tr> <th>迭代 Iter/ms</th> <th>递归 Rec/ms</th> </tr> <?php rowTable(); ?></table>
5000次执行时间效率对比
模式/执行ms时间 | 平均数(数组长度1000) | 方差(数组长度1000) |
---|---|---|
迭代 Iter /ms | 2.840572476 | 0.03862993 |
递归 Rec /ms | 3.071363568 | 0.06567554 |
模式 | 平均数(数组长度400) | 方差(数组长度400) |
---|---|---|
迭代 Iter /ms | 0.987666035 | 0.015847294 |
递归 Rec /ms | 0.987947607 | 0.036398175 |
模式 | 平均数(数组长度50) | 方差(数组长度50) |
---|---|---|
迭代 Iter /ms | 0.081454897 | 0.000522679 |
递归 Rec /ms | 0.066546392 | 0.000362922 |
实现代码
代码地址:https://github.com/ParrySMS/Exp/tree/master/ProLang/quickSort
递归法 quickSortRec.php
<?php/** * Created by PhpStorm. * User: L * Date: 2018-4-13 * Time: 23:27 *//** 递归法快排序 * @param array $ar * @return array */function quickSortR(array $ar){ //判断数组长度 $size = sizeof($ar); if($size<=1){ return $ar; } //用两个数组分别接受比游标key小和比key大的数据 $left = array(); $right = array(); $key = $ar[0]; for($i =1;$i<$size;$i++){ if($ar[$i]<=$key){ $left[] = $ar[$i]; }else{ $right[] = $ar[$i]; } } //内部再进行排序 $left = quickSortR($left); $right = quickSortR($right); //最后合并 return array_merge($left,array($key),$right); }
迭代法 quickSortIter.php
<?php/** * Created by PhpStorm. * User: L * Date: 2018-4-14 * Time: 14:51 *//** 迭代法 * @param array $ar * @return array */function quickSortI(array $ar){ $stack = array($ar); $sort = array(); //判断数组长度 $size = sizeof($ar); if ($size <= 1) { return $ar; } //栈空即跳出循环 while ($stack) { $arr = array_pop($stack); if (count($arr) <= 1) { if (count($arr) == 1) { $sort[] = &$arr[0]; } continue; } $key = $arr[0]; $high = array(); $low = array(); //用两个数组分别接受比游标key小和比key大的数据 $_size = count($arr); for ($i = 1; $i < $_size; $i++) { if ($arr[$i] <= $key) { $high[] = &$arr[$i]; } else { $low[] = &$arr[$i]; } } if (!empty($low)) {//数据入站 array_push($stack, $low); } array_push($stack, array($arr[0])); if (!empty($high)) { array_push($stack, $high); } } return $sort; }
执行时间测试脚本 test.php
<?php/**
* Created by PhpStorm.
* User: L
* Date: 2018-4-17
* Time: 23:45
*/require "quickSortIter.php";require "quickSortRec.php";
define('SORT_TIMES', 100);
define('SIZE', 1000);function rowTable(){
unset($row); $row = array(); for ($i = 0; $i < SORT_TIMES; $i++) { $row = getSortRow($row);
} foreach ($row as $r) { print <<< TR
<tr>
<td>$r->iter</td>
<td>$r->rec</td>
</tr>
TR;
}
}function getSortRow(array $row){
unset($ar); $ar = array(); for ($i = 0; $i < SIZE; $i++) { $ar[] = rand(0, SIZE*2);
} $stime = microtime(true); $recAr = quickSortR($ar); $etime = microtime(true); $recTime = 1000 * ($etime - $stime);// echo"<br/>";
$stime = microtime(true); $iterAr = quickSortI($ar); $etime = microtime(true); $iterTime = 1000 * ($etime - $stime);// print_r($recAr);// echo "<br/>";// print_r($iterAr);
$row[] = (object)["iter" => $iterTime, "rec" => $recTime]; return $row;
}?><table border="1">
<tr>
<th>迭代 Iter/ms</th>
<th>递归 Rec/ms</th>
</tr> <?php rowTable(); ?></table>
반복적 방법 quickSortIter.php
rrreee
실행 시간 테스트 스크립트 test.php
Mode/Execution ms time | Average(배열 길이 1000) | |
---|---|---|
반복 반복 /ms | 2.840572476 | |
재귀 기록 /ms | 3.071363 568 |
Mode | 평균 숫자(배열 길이 400) | |
---|---|---|
Iteration Iter /ms | 0.987666035 | |
Recursive Rec /ms | 0.987947607 |
... | Recursive Rec/ms0.066546392 | 0.000362922 |
---|---|---|
구현 코드 | 코드 주소: https://github.com/ParrySMS/Exp/tree/master/ProLang/quickSort | 재귀 메서드 quickSortRec .php
| rrreee
실행 시간 테스트 스크립트 test.php
| rrreee5000 실행 시간 효율성 비교 |
| 모드/실행 ms 시간
위 내용은 PHP 빠른 정렬 문제에 대한 재귀 알고리즘 구현 및 반복 알고리즘 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

PHP는 현대화 프로세스에서 많은 웹 사이트 및 응용 프로그램을 지원하고 프레임 워크를 통해 개발 요구에 적응하기 때문에 여전히 중요합니다. 1.PHP7은 성능을 향상시키고 새로운 기능을 소개합니다. 2. Laravel, Symfony 및 Codeigniter와 같은 현대 프레임 워크는 개발을 단순화하고 코드 품질을 향상시킵니다. 3. 성능 최적화 및 모범 사례는 응용 프로그램 효율성을 더욱 향상시킵니다.

phphassignificallyimpactedwebdevelopmentandextendsbeyondit

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.

PHP에서는 클론 키워드를 사용하여 객체 사본을 만들고 \ _ \ _ Clone Magic 메소드를 통해 클로닝 동작을 사용자 정의하십시오. 1. 복제 키워드를 사용하여 얕은 사본을 만들어 객체의 속성을 복제하지만 객체의 속성은 아닙니다. 2. \ _ \ _ 클론 방법은 얕은 복사 문제를 피하기 위해 중첩 된 물체를 깊이 복사 할 수 있습니다. 3. 복제의 순환 참조 및 성능 문제를 피하고 클로닝 작업을 최적화하여 효율성을 향상시키기 위해주의를 기울이십시오.

PHP는 웹 개발 및 컨텐츠 관리 시스템에 적합하며 Python은 데이터 과학, 기계 학습 및 자동화 스크립트에 적합합니다. 1.PHP는 빠르고 확장 가능한 웹 사이트 및 응용 프로그램을 구축하는 데 잘 작동하며 WordPress와 같은 CMS에서 일반적으로 사용됩니다. 2. Python은 Numpy 및 Tensorflow와 같은 풍부한 라이브러리를 통해 데이터 과학 및 기계 학습 분야에서 뛰어난 공연을했습니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

WebStorm Mac 버전
유용한 JavaScript 개발 도구

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전
