머리말
다음은 PHP를 통해 구현된 고전적인 알고리즘이며, 시간 소모를 계산해 보면 이러한 알고리즘의 복잡도를 시간 소모로 비교할 수 있습니다.
- 삽입 정렬
- 버블 정렬
- 선택 정렬
- 병합 정렬
- 퀵 정렬
CODE
<code><span>$arr</span> = []; <span>for</span> (<span>$i</span> = <span>0</span>; <span>$i</span> 5000; <span>$i</span>++) { <span>$arr</span>[] = rand(<span>1</span>, <span>10000</span>); } <span>//1 插入排序</span><span><span>function</span><span>insertionSort</span><span>(<span>$arr</span>)</span> {</span><span>for</span> (<span>$i</span> = <span>1</span>; <span>$i</span> $arr); <span>$i</span>++) { <span>$tmp</span> = <span>$arr</span>[<span>$i</span>]; <span>//设置监视哨</span><span>$key</span> = <span>$i</span> - <span>1</span>; <span>//设置开始查找的位置</span><span>while</span> (<span>$key</span> >= <span>0</span> && <span>$tmp</span> $arr[<span>$key</span>]) { <span>// 监视哨的值比查找的值小 并且 没有到此次查询的第一个</span><span>$arr</span>[<span>$key</span> + <span>1</span>] = <span>$arr</span>[<span>$key</span>]; <span>//数组的值进行后移</span><span>$key</span>--; <span>//要查找的位置后移</span> } <span>if</span> ((<span>$key</span> + <span>1</span>) != <span>$i</span>) <span>//放置监视哨</span><span>$arr</span>[<span>$key</span> + <span>1</span>] = <span>$tmp</span>; } <span>return</span><span>$arr</span>; } <span>$insertion_start_time</span> = microtime(<span>true</span>); <span>$insertion_sort</span> = insertionSort(<span>$arr</span>); <span>$insertion_end_time</span> = microtime(<span>true</span>); <span>$insertion_need_time</span> = <span>$insertion_end_time</span> - <span>$insertion_start_time</span>; print_r(<span>"插入排序耗时:"</span> . <span>$insertion_need_time</span> . <span>"<br>"</span>); <span>//2 冒泡排序</span><span><span>function</span><span>bubbleSort</span><span>(<span>$arr</span>)</span> {</span><span>for</span> (<span>$i</span> = <span>0</span>; <span>$i</span> $arr); <span>$i</span>++) { <span>for</span> (<span>$j</span> = <span>0</span>; <span>$j</span> $i + <span>1</span>; <span>$j</span>++) { <span>if</span> (<span>$arr</span>[<span>$j</span>] $arr[<span>$j</span> - <span>1</span>]) { <span>$temp</span> = <span>$arr</span>[<span>$j</span> - <span>1</span>]; <span>$arr</span>[<span>$j</span> - <span>1</span>] = <span>$arr</span>[<span>$j</span>]; <span>$arr</span>[<span>$j</span>] = <span>$temp</span>; } } } <span>return</span><span>$arr</span>; } <span>$bubble_start_time</span> = microtime(<span>true</span>); <span>$bubble_sort</span> = bubbleSort(<span>$arr</span>); <span>$bubble_end_time</span> = microtime(<span>true</span>); <span>$bubble_need_time</span> = <span>$bubble_end_time</span> - <span>$bubble_start_time</span>; print_r(<span>"冒泡排序耗时:"</span> . <span>$bubble_need_time</span> . <span>"<br>"</span>); <span>//3 选择排序</span><span><span>function</span><span>selectionSort</span><span>(<span>$arr</span>)</span> {</span><span>$count</span> = count(<span>$arr</span>); <span>for</span> (<span>$i</span> = <span>0</span>; <span>$i</span> $count - <span>1</span>; <span>$i</span>++) { <span>//找到最小的值</span><span>$min</span> = <span>$i</span>; <span>for</span> (<span>$j</span> = <span>$i</span> + <span>1</span>; <span>$j</span> $count; <span>$j</span>++) { <span>//由小到大排列</span><span>if</span> (<span>$arr</span>[<span>$min</span>] > <span>$arr</span>[<span>$j</span>]) { <span>//表明当前最小的还比当前的元素大</span><span>$min</span> = <span>$j</span>; <span>//赋值新的最小的</span> } } <span>/*swap$array[$i]and$array[$min]即将当前内循环的最小元素放在$i位置上*/</span><span>if</span> (<span>$min</span> != <span>$i</span>) { <span>$temp</span> = <span>$arr</span>[<span>$min</span>]; <span>$arr</span>[<span>$min</span>] = <span>$arr</span>[<span>$i</span>]; <span>$arr</span>[<span>$i</span>] = <span>$temp</span>; } } <span>return</span><span>$arr</span>; } <span>$selection_start_time</span> = microtime(<span>true</span>); <span>$selection_sort</span> = selectionSort(<span>$arr</span>); <span>$selection_end_time</span> = microtime(<span>true</span>); <span>$selection_need_time</span> = <span>$selection_end_time</span> - <span>$selection_start_time</span>; print_r(<span>"选择排序耗时:"</span> . <span>$selection_need_time</span> . <span>"<br>"</span>); <span>//4 并归排序</span><span>//merge函数将指定的两个有序数组(arr1arr2,)合并并且排序</span><span>//我们可以找到第三个数组,然后依次从两个数组的开始取数据哪个数据小就先取哪个的,然后删除掉刚刚取过///的数据</span><span><span>function</span><span>al_merge</span><span>(<span>$arrA</span>, <span>$arrB</span>)</span> {</span><span>$arrC</span> = <span>array</span>(); <span>while</span> (count(<span>$arrA</span>) && count(<span>$arrB</span>)) { <span>//这里不断的判断哪个值小,就将小的值给到arrC,但是到最后肯定要剩下几个值,</span><span>//不是剩下arrA里面的就是剩下arrB里面的而且这几个有序的值,肯定比arrC里面所有的值都大所以使用</span><span>$arrC</span>[] = <span>$arrA</span>[<span>'0'</span>] $arrB[<span>'0'</span>] ? array_shift(<span>$arrA</span>) : array_shift(<span>$arrB</span>); } <span>return</span> array_merge(<span>$arrC</span>, <span>$arrA</span>, <span>$arrB</span>); } <span>//归并排序主程序</span><span><span>function</span><span>al_merge_sort</span><span>(<span>$arr</span>)</span> {</span><span>$len</span> = count(<span>$arr</span>); <span>if</span> (<span>$len</span> 1) <span>return</span><span>$arr</span>;<span>//递归结束条件,到达这步的时候,数组就只剩下一个元素了,也就是分离了数组</span><span>$mid</span> = intval(<span>$len</span> / <span>2</span>);<span>//取数组中间</span><span>$left_arr</span> = array_slice(<span>$arr</span>, <span>0</span>, <span>$mid</span>);<span>//拆分数组0-mid这部分给左边left_arr</span><span>$right_arr</span> = array_slice(<span>$arr</span>, <span>$mid</span>);<span>//拆分数组mid-末尾这部分给右边right_arr</span><span>$left_arr</span> = al_merge_sort(<span>$left_arr</span>);<span>//左边拆分完后开始递归合并往上走</span><span>$right_arr</span> = al_merge_sort(<span>$right_arr</span>);<span>//右边拆分完毕开始递归往上走</span><span>$arr</span> = al_merge(<span>$left_arr</span>, <span>$right_arr</span>);<span>//合并两个数组,继续递归</span><span>return</span><span>$arr</span>; } <span>$merge_start_time</span> = microtime(<span>true</span>); <span>$merge_sort</span> = al_merge_sort(<span>$arr</span>); <span>$merge_end_time</span> = microtime(<span>true</span>); <span>$merge_need_time</span> = <span>$merge_end_time</span> - <span>$merge_start_time</span>; print_r(<span>"并归排序耗时:"</span> . <span>$merge_need_time</span> . <span>"<br>"</span>); <span>//5 快速排序</span><span><span>function</span><span>quickSort</span><span>(&<span>$arr</span>)</span>{</span><span>if</span>(count(<span>$arr</span>)><span>1</span>){ <span>$k</span>=<span>$arr</span>[<span>0</span>]; <span>$x</span>=<span>array</span>(); <span>$y</span>=<span>array</span>(); <span>$_size</span>=count(<span>$arr</span>); <span>for</span>(<span>$i</span>=<span>1</span>;<span>$i</span>$_size;<span>$i</span>++){ <span>if</span>(<span>$arr</span>[<span>$i</span>]$k){ <span>$x</span>[]=<span>$arr</span>[<span>$i</span>]; }<span>elseif</span>(<span>$arr</span>[<span>$i</span>]><span>$k</span>){ <span>$y</span>[]=<span>$arr</span>[<span>$i</span>]; } } <span>$x</span>=quickSort(<span>$x</span>); <span>$y</span>=quickSort(<span>$y</span>); <span>return</span> array_merge(<span>$x</span>,<span>array</span>(<span>$k</span>),<span>$y</span>); }<span>else</span>{ <span>return</span><span>$arr</span>; } } <span>$quick_start_time</span> = microtime(<span>true</span>); <span>$quick_sort</span> = al_merge_sort(<span>$arr</span>); <span>$quick_end_time</span> = microtime(<span>true</span>); <span>$quick_need_time</span> = <span>$quick_end_time</span> - <span>$quick_start_time</span>; print_r(<span>"快速排序耗时:"</span> . <span>$quick_need_time</span> . <span>"<br>"</span>); </code>
시간이 많이 걸리는 비교
삽입 정렬 시간이 많이 소요됨: 1.2335460186005
버블 정렬 시간: 2.6180219650269
선택 정렬 시간: 1.4159741401672
병합 정렬에 걸린 시간: 0.17212891578674
빠른 정렬에는 시간이 걸립니다: 0.16736888885498
참조
- 알고리즘 소개
위 내용은 PHP와 고전적인 측면을 포함하여 PHP의 고전적인 알고리즘 구현을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

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

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

뜨거운 주제



