亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 邏輯算法 > 正文

PHP面試題之算法題

2020-03-22 18:46:54
字體:
來源:轉載
供稿:網友
php面試題中也會經常出現算法題,本文主要和大家分享PHP面試題之算法題,希望能幫助到大家。

面試題——算法題:

1、插入排序(一維數組) 基本思想:每次將一個待排序的數據元素,插入到前面已經排好序的數列中的適當位置,使數列依然有序;直到待排序數據元素全部插入完為止。 示例:

[初始關鍵字] [49] 38 65 97 76 13 27 49
J=2(38) [38 49] 65 97 76 13 27 49
J=3(65) [38 49 65] 97 76 13 27 49
J=4(97) [38 49 65 97] 76 13 27 49
J=5(76) [38 49 65 76 97] 13 27 49
J=6(13) [13 38 49 65 76 97] 27 49
J=7(27) [13 27 38 49 65 76 97] 49
J=8(49) [13 27 38 49 49 65 76 97]

function insert_sort($arr){    $count = count($arr);     for($i=1; $i<$count; $i++){         $tmp = $arr[$i];          $j = $i - 1;          while($arr[$j] > $tmp){              $arr[$j+1] = $arr[$j];              $arr[$j] = $tmp;              $j--;          }      }      return $arr; }

2、選擇排序(一維數組) 基本思想:每一趟從待排序的數據元素中選出最?。ɑ蜃畲螅┑囊粋€元素,順序放在已排好序的數列的最后,直到全部待排序的數據元素排完。 示例:

[初始關鍵字] [49 38 65 97 76 13 27 49]
第一趟排序后 13 [38 65 97 76 49 27 49]
第二趟排序后 13 27 [65 97 76 49 38 49]
第三趟排序后 13 27 38 [97 76 49 65 49]
第四趟排序后 13 27 38 49 [49 97 65 76]
第五趟排序后 13 27 38 49 49 [97 97 76]
第六趟排序后 13 27 38 49 49 76 [76 97]
第七趟排序后 13 27 38 49 49 76 76 [ 97]
最后排序結果 13 27 38 49 49 76 76 97

function select_sort($arr){     $count = count($arr);     for($i=0; $i<$count; $i++){         $k = $i;          for($j=$i+1; $j<$count; $j++){              if ($arr[$k] > $arr[$j]) $k = $j;         }         if($k != $i){             $tmp = $arr[$i];             $arr[$i] = $arr[$k];             $arr[$k] = $tmp;         }     }     return $arr; }

3、冒泡排序(一維數組) 基本思想:兩兩比較待排序數據元素的大小,發現兩個數據元素的次序相反時即進行交換,直到沒有反序的數據元素為止。 排序過程:設想被排序的數組R[1..N]垂直豎立,將每個數據元素看作有重量的氣泡,根據輕氣泡不能在重氣泡之下的原則, 從下往上掃描數組R,凡掃描到違反本原則的輕氣泡,就使其向上”漂浮”,如此反復進行,直至最后任何兩個氣泡都是輕者在上,重者在下為止。 示例:

49 13 13 13 13 13 13 13
38 49 27 27 27 27 27 27
65 38 49 38 38 38 38 38
97 65 38 49 49 49 49 49
76 97 65 49 49 49 49 49
13 76 97 65 65 65 65 65
27 27 76 97 76 76 76 76
49 49 49 76 97 97 97 97

function bubble_sort($array){     $count = count($array);     if ($count <= 0) return false;     for($i=0; $i<$count; $i++){         for($j=$count-1; $j>$i; $j--){             if ($array[$j]<$array[$j-1]){                 $tmp = $array[$j];                 $array[$j] = $array[$j-1];                 $array[$j-1] = $tmp;             }         }     }      return $array; }

4、快速排序(一維數組) 基本思想:在當前無序區R[1..H]中任取一個數據元素作為比較的”基準”(不妨記為X), 用此基準將當前無序區劃分為左右兩個較小的無序區:R[1..I-1]和R[I 1..H],且左邊的無序子區中數據元素均小于等于基準元素, 右邊的無序子區中數據元素均大于等于基準元素,而基準X則位于最終排序的位置上,即R[1..I-1]≤X.Key≤RI 1..H, 當 R[1..I-1]和R[I 1..H]均非空時,分別對它們進行上述的劃分過程,直至所有無序子區中的數據元素均已排序為止。 示例:

初始關鍵字 [49 38 65 97 76 13 27 49]
第一次交換后 [27 38 65 97 76 13 49 49]
第二次交換后 [27 38 49 97 76 13 65 49]
J向左掃描,位置不變,第三次交換后 [27 38 13 97 76 49 65 49]
I向右掃描,位置不變,第四次交換后 [27 38 13 49 76 97 65 49]
J向左掃描 [27 38 13 49 76 97 65 49]
(一次劃分過程)
初始關鍵字 [49 38 65 97 76 13 27 49]
一趟排序之后 [27 38 13] 49 [76 97 65 49]
二趟排序之后 [13] 27 [38] 49 [49 65]76 [97]
三趟排序之后 13 27 38 49 49 [65]76 97
最后的排序結果 13 27 38 49 49 65 76 97
各趟排序之后的狀態

function quickSort(&$arr){    if(count($arr)>1){        $k=$arr[0];        $x=array();        $y=array();        $_size=count($arr);        for($i=1;$i<$_size;$i++){            if($arr[$i]<=$k){                $x[]=$arr[$i];            }elseif($arr[$i]>$k){                $y[]=$arr[$i];            }        }        $x=quickSort($x);        $y=quickSort($y);        return array_merge($x,array($k),$y);    }else{        return$arr;    }}

5、希爾排序(shell sort)— O(n log n)

functionshell_sort(&$arr){    if(!is_array($arr))return;$n=count($arr);    for($gap=floor($n/2);$gap>0;$gap=floor($gap/=2)){        for($i=$gap;$i<$n;++$i){            for($j=$i-$gap;$j>=0&&$arr[$j+$gap]<$arr[$j];$j-=$gap){                $temp=$arr[$j];                $arr[$j]=$arr[$j+$gap];                $arr[$j+$gap]=$temp;            }        }    }}

6、二分查找

/** * 二分算法查找 * @param array $array 要查找的數組 * @param int $min_key 數組的最小下標 * @param int $max_key 數組的最大下標 * @param mixed $html' target='_blank'>value 要查找的值 * @return boolean */ function bin_search($array,$min_key,$max_key,$value){             if($min_key <= $max_key){         $key = intval(($min_key+$max_key)/2);         if($array[$key] == $value){             return true;         }elseif($value < $array[$key]){             return bin_search($array,$min_key,$key-1,$value);        }else{             return bin_search($array,$key+1,$max_key,$value);        }     }else{         return false;     } }

7、線性表的刪除(數組中實現)

function delete_array_element($array, $i){     $len = count($array);     for ($j=$i; $j<$len; $j++){         $array[$j] = $array[$j+1]     }     array_pop($array);     return $array; }

8、字符串長度

function strlen($str){     if ($str == '') return 0;     $count = 0;     while (1){         if ($str[$count] != NULL){             $count++;             continue;         }else{             break;         }     }     return $count; }

9、字符串翻轉

function strrev($str){     if ($str == '') return 0;     for ($i=(strlen($str)-1); $i>=0; $i--){          $rev_str .= $str[$i];     }     return $rev_str; }

10、字符串比較

function strcmp($s1, $s2){     if (strlen($s1) < strlen($s2)) return -1;     if (strlen($s1) > strlen($s2)) return 1;     for ($i=0; $i<strlen($s1); $i++){         if ($s1[$i] == $s2[$i]){             continue;         }else{             return false;         }     }     return 0; }

11、查找字符串

function strstr($str, $substr){     $m = strlen($str);     $n = strlen($substr);     if ($m < $n) return false;     for ($i=0; $i<=($m-$n+1); $i++){         $sub = substr($str, $i, $n);         if (strcmp($sub, $substr) == 0) return $i;     }     return false; }

12、字符串替換

function str_replace($substr, $newsubstr, $str){     $m = strlen($str);     $n = strlen($substr);     $x = strlen($newsubstr);     if (strchr($str, $substr) == false) return false;     for ($i=0; $i<=($m-$n+1); $i++){         $i = strchr($str, $substr);         $str = str_delete($str, $i, $n);         $str = str_insert($str, $i, $newstr);     }     return $str; }

13、插入一段字符串

function str_insert($str, $i, $substr){     for($j=0; $j<$i; $j++){         $startstr .= $str[$j];     }     for ($j=$i; $j<strlen($str); $j++){         $laststr .= $str[$j];     }     $str = ($startstr . $substr . $laststr);     return $str; }

14、刪除一段字符串

function str_delete($str, $i, $j){     for ($c=0; $c<$i; $c++){         $startstr .= $str[$c];     }     for ($c=($i+$j); $c<strlen($str); $c++){         $laststr .= $str[$c];     }     $str = ($startstr . $laststr);     return $str; }

15、復制字符串

function strcpy($s1, $s2){     if (strlen($s1)==NULL || !isset($s2)) return;     for ($i=0; $i<strlen($s1); $i++){         $s2[] = $s1[$i];     }     return $s2; }

16、連接字符串

function strcat($s1, $s2){     if (!isset($s1) || !isset($s2)) return;     $newstr = $s1;     for($i=0; $i<count($s); $i++){         $newstr .= $st[$i];     }     return $newsstr; }

17、簡單編碼函數(與php_decode函數對應)

function php_encode($str){ if ($str=='' && strlen($str)>128) return false; for($i=0; $i<strlen($str); $i++){ $c = ord($str[$i]); if ($c>31 && $c<107) $c += 20; if ($c>106 && $c<127) $c -= 75; $word = chr($c); $s .= $word; } return $s; }

18、簡單解碼函數(與php_encode函數對應)

function php_decode($str){     if ($str=='' && strlen($str)>128) return false;     for($i=0; $i<strlen($str); $i++){         $c = ord($word);         if ($c>106 && $c<127) $c = $c-20;         if ($c>31 && $c<107) $c = $c+75;         $word = chr($c);         $s .= $word;     }     return $s; }

19、簡單加密函數(與php_decrypt函數對應)

function php_encrypt($str){     $encrypt_key = 'abcdefghijklmnopqrstuvwxyz1234567890';    $decrypt_key = 'ngzqtcobmuhelkpdawxfyivrsj2468021359';     if (strlen($str) == 0) return false;      for ($i=0; $i<strlen($str); $i++){          for ($j=0; $j<strlen($encrypt_key); $j++){              if ($str[$i] == $encrypt_key[$j]){                  $enstr .= $decrypt_key[$j];                  break;              }          }      }     return $enstr; }

20、簡單解密函數(與php_encrypt函數對應)

function php_decrypt($str){     $encrypt_key = 'abcdefghijklmnopqrstuvwxyz1234567890';    $decrypt_key = 'ngzqtcobmuhelkpdawxfyivrsj2468021359';     if (strlen($str) == 0) return false;     for ($i=0; $i<strlen($str); $i++){         for ($j=0; $j<strlen($decrypt_key); $j++){             if ($str[$i] == $decrypt_key[$j]){                 $enstr .= $encrypt_key[$j];                 break;             }         }     }     return $enstr; }

相關推薦:

php的經典算法題之分蘋果

一條項目中常用的linux命令引發的經典算法題

淺談js中字符和數組一些基本算法題

以上就是PHP面試題之算法題的詳細內容,更多請關注 其它相關文章!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
视频在线观看99| 国产精品视频久久久久| 亚洲成av人影院在线观看| 精品国产一区二区三区久久狼5月| 欧美资源在线观看| 日韩成人在线免费观看| 国产午夜一区二区| 亚洲最大av在线| 992tv在线成人免费观看| 日韩精品免费综合视频在线播放| 亚洲第一国产精品| 91九色综合久久| 欧美成人免费大片| 中文字幕欧美专区| 欧美成人精品在线观看| 亚洲毛茸茸少妇高潮呻吟| 一本大道香蕉久在线播放29| 伊人久久久久久久久久久久久| 久久精品中文字幕一区| 亚洲欧洲在线播放| 97久久伊人激情网| 亚洲人成亚洲人成在线观看| 亚洲精品免费一区二区三区| 精品国产91乱高清在线观看| 久久精品亚洲94久久精品| 亚洲精品自产拍| 国产精品福利在线观看网址| 久久久精品2019中文字幕神马| 国模精品系列视频| 一本色道久久综合狠狠躁篇的优点| 久久久精品一区| 亚洲国产精品人人爽夜夜爽| 亚洲国产精品成人va在线观看| 最近2019好看的中文字幕免费| 国产综合色香蕉精品| 亚洲精品一区二区网址| 亚洲激情视频在线| 亚洲欧美日韩国产中文专区| 国产精品va在线播放我和闺蜜| 自拍偷拍亚洲欧美| 亚洲最大福利视频| 久久夜色精品国产欧美乱| 成人a在线观看| 人人澡人人澡人人看欧美| 欧美日韩一二三四五区| 久久99国产精品自在自在app| 欧美日韩国产在线| 琪琪亚洲精品午夜在线| 欧美xxxx18国产| 欧美激情精品久久久久久久变态| 国产精品99久久久久久久久| 亚洲最大福利视频| 欧美午夜宅男影院在线观看| 国产69久久精品成人看| 国产精品夫妻激情| 亚洲一区二区三区sesese| 91久久久久久国产精品| 国产裸体写真av一区二区| 久久天天躁狠狠躁夜夜av| 亚洲精美色品网站| 欧美国产高跟鞋裸体秀xxxhd| 成人av.网址在线网站| 欧美激情一级精品国产| 欧美午夜宅男影院在线观看| 亚洲成人教育av| 欧美日韩爱爱视频| 中文字幕亚洲精品| 亚洲天堂网站在线观看视频| 在线亚洲男人天堂| 久久97久久97精品免视看| 欧美激情一级二级| 精品国产乱码久久久久久天美| 日韩久久免费视频| 日韩在线观看网址| 日韩中文娱乐网| 精品亚洲精品福利线在观看| 91视频免费网站| 精品亚洲aⅴ在线观看| 欧美在线视频一区| 日韩中文字幕网| 久久琪琪电影院| 亚洲天堂免费视频| 亚洲bt天天射| 永久免费精品影视网站| 日本精品一区二区三区在线播放视频| 91久久久久久| 韩国日本不卡在线| 亚洲第一精品久久忘忧草社区| 国产成人一区二区| 精品伊人久久97| 午夜精品久久17c| 伊人久久免费视频| 日韩av电影在线免费播放| 亚洲高清色综合| 久久最新资源网| 亚洲视频在线观看视频| 激情成人在线视频| 亚洲一区999| 亚洲男人天堂久| www高清在线视频日韩欧美| 欧美亚洲国产另类| 精品福利一区二区| 欧美极品少妇xxxxⅹ免费视频| 日韩久久午夜影院| 夜夜狂射影院欧美极品| 国产亚洲精品久久久久久牛牛| 亚洲精品黄网在线观看| 久久人人爽国产| 97视频在线播放| 国产精品久久久久91| 亚洲va男人天堂| 国产精品视频最多的网站| 亚洲a区在线视频| 久久在线免费观看视频| 2019亚洲日韩新视频| 日韩专区在线观看| 日韩视频在线观看免费| 91夜夜揉人人捏人人添红杏| 日韩av手机在线| 日韩精品在线观看网站| 国产一区二区三区精品久久久| 亚洲影影院av| 77777少妇光屁股久久一区| 久久久亚洲精选| 中文字幕一区电影| 欧美激情欧美激情在线五月| 久久久久久亚洲精品| 亚洲精品永久免费精品| 不卡伊人av在线播放| 97色在线视频| 日韩中文有码在线视频| 国产专区欧美专区| 日韩中文字幕视频在线观看| 日韩欧美成人区| 精品久久久久久久久久| 欧美成人网在线| 亚洲精品永久免费精品| 亚洲国产中文字幕久久网| 久久国产精品久久久| 欧美黑人巨大xxx极品| 成人国产精品日本在线| 国产v综合ⅴ日韩v欧美大片| 久久久久久网站| 国产精品jizz在线观看麻豆| 日韩在线视频国产| 亚洲国产精彩中文乱码av在线播放| 麻豆国产va免费精品高清在线| 久久精品国产亚洲一区二区| 在线精品国产成人综合| 亚洲毛片在线看| 国产精品白嫩美女在线观看| 亚洲人成在线免费观看| 美女久久久久久久久久久| 日韩精品一区二区视频| 欧美激情视频播放| 欧美日韩第一视频| 国产成人精品免费视频| 日韩在线视频国产| 色妞色视频一区二区三区四区| 精品国产一区av| 一区二区av在线| 亚洲美女免费精品视频在线观看| 国产v综合v亚洲欧美久久| 亚洲日本中文字幕免费在线不卡|