国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

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

PHP面試題之算法題

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

面試題——算法題:

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

[初始關鍵字] [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、選擇排序(一維數(shù)組) 基本思想:每一趟從待排序的數(shù)據(jù)元素中選出最小(或最大)的一個元素,順序放在已排好序的數(shù)列的最后,直到全部待排序的數(shù)據(jù)元素排完。 示例:

[初始關鍵字] [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、冒泡排序(一維數(shù)組) 基本思想:兩兩比較待排序數(shù)據(jù)元素的大小,發(fā)現(xiàn)兩個數(shù)據(jù)元素的次序相反時即進行交換,直到?jīng)]有反序的數(shù)據(jù)元素為止。 排序過程:設想被排序的數(shù)組R[1..N]垂直豎立,將每個數(shù)據(jù)元素看作有重量的氣泡,根據(jù)輕氣泡不能在重氣泡之下的原則, 從下往上掃描數(shù)組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、快速排序(一維數(shù)組) 基本思想:在當前無序區(qū)R[1..H]中任取一個數(shù)據(jù)元素作為比較的”基準”(不妨記為X), 用此基準將當前無序區(qū)劃分為左右兩個較小的無序區(qū):R[1..I-1]和R[I 1..H],且左邊的無序子區(qū)中數(shù)據(jù)元素均小于等于基準元素, 右邊的無序子區(qū)中數(shù)據(jù)元素均大于等于基準元素,而基準X則位于最終排序的位置上,即R[1..I-1]≤X.Key≤RI 1..H, 當 R[1..I-1]和R[I 1..H]均非空時,分別對它們進行上述的劃分過程,直至所有無序子區(qū)中的數(shù)據(jù)元素均已排序為止。 示例:

初始關鍵字 [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
各趟排序之后的狀態(tài)

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 要查找的數(shù)組 * @param int $min_key 數(shù)組的最小下標 * @param int $max_key 數(shù)組的最大下標 * @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、線性表的刪除(數(shù)組中實現(xiàn))

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、簡單編碼函數(shù)(與php_decode函數(shù)對應)

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、簡單解碼函數(shù)(與php_encode函數(shù)對應)

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、簡單加密函數(shù)(與php_decrypt函數(shù)對應)

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、簡單解密函數(shù)(與php_encrypt函數(shù)對應)

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的經(jīng)典算法題之分蘋果

一條項目中常用的linux命令引發(fā)的經(jīng)典算法題

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

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

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
99中文字幕一区| 国产精品剧情一区二区在线观看| 中文字幕在线免费视频| 国产在线高潮| 国产一级片麻豆| 国产99re| 日本不卡1区2区3区| 国产女人伦码一区二区三区不卡| 国产尤物视频| 国产精品视频二区三区| 国产精品冒白浆免费视频| 国产国产人免费人成免费视频| 国产黄色高清在线| 超碰国产在线| 国产视频你懂的| 日本欧洲一区| 九九热免费在线视频| 午夜视频在线看| 国产成人久久精品77777| 亚洲欧美精品日韩欧美 | 国产变态拳头交视频一区二区| 国产91久久久久蜜臀青青天草二| 国产成a人亚洲精v品| www在线视频观看| 91桃色在线| 国产一级大片| 另类高清dbsm日本tvav| 影音先锋在线中文字幕| 国产在线观看a| 亚洲色婷婷综合开心网| 国产日韩网站| 狂野欧美性猛交xxxx乱大交| 在线免费看黄av| 2020亚洲男人天堂| 国产亚洲精品自在线观看| 免费男女羞羞的视频网站中文字幕| 国产不卡一卡2卡三卡4卡5卡在线| 四虎网站在线观看| 在线āv视频| 在线免费观看你懂的| 国产黄色在线| 国产精品伦一区二区三区级视频频| 美女网站在线观看| 天海翼中文字幕| 天堂√中文在线| 日本国产在线| 久久精品视频免费看| www在线视频观看| 九九精品九九| 天天操天天曰| 国产黄在线看| 在线视频福利| 色悠久久久久综合网小说| 亚洲电影视频在线| 黄色一级片视频| 午夜视频在线看| 91极品在线| 青青久草在线| 黄网站app在线观看下载视频大全官网| 久久er视频| 国产小视频在线高清播放| 国产区视频在线播放| 国产99re| 快射av在线播放一区| 国产丝袜在线播放| 在线视频1区2区| 高清色视频在线观看| 国产三级视频在线看| 亚洲人成影院在线| 国产一级性片| www.国产精| 国产秒拍福利视频露脸| 国产女主播在线| 伊人资源视频在线| √天堂中文在线| 在线免费日韩| 中文字幕在线第一页| 亚洲精品aaaa精品| 国产黄色在线播放| 激情在线视频播放| 中文在线观看视频| 国产一区精品| 超碰在线国产| www.超级碰| 国产高清免费在线播放| 日本动漫同人动漫在线观看| 国产精品麻豆一区二区三区| 免费看ww视频网站入口| 2018狠狠干| 中文字幕国产在线| 狠狠操天天操夜夜操| 精品视频一区二区观看| 尤物视频在线免费观看| 男人操女人免费网站| 亚洲第一成年免费网站| 18成年在线观看| 国产精品人人| 国产激情视频在线观看| 国产精品一区二区婷婷| 蜜桃av网站| 久久精品国产亚洲a∨麻豆| 免费av在线| 高清av中文在线字幕观看1| 69久久精品| 精品视频一区二区观看| 精品国语对白精品自拍视| 国产色在线观看| 国产精品入口麻豆电影| 国产精品免费麻豆入口| 97国产在线| 在线视频中文字幕第一页| 伊人网在线免费观看| 亚洲欧美综合乱码精品成人网| 精品成人免费自拍视频| 在线中文字幕资源| 中文天堂av| 男人天堂v视频| 最近中文av字幕在线中文| 中中文字幕av在线| 中文字幕在线资源| 国产成人综合美国十次| 欧美日韩久久中文字幕| 丁香综合在线| 国产精品麻豆一区二区三区 | 国产porn在线| av网站在线播放| 久久国产精品久久久久久小说| 国产尤物一区二区三区| 国产视频第一区| 亚洲综合在线不卡| 免费看av大片| 国产精品理人伦一区二区三区| 一个人看的www免费观看视频| 人成在线免费视频| 国产精品一区二区婷婷| 伊人222成人综合网| 国产中文在线视频| 伊人影院在线播放| 国产视频xxx| 久久久久久77777| 亚洲尤物在线视频| 91啦中文在线| 五月婷婷在线视频| 成人超碰在线| 日本在线观看网站| 国产一区二区三区福利| eeuss影院在线观看第一页| 国产视频xxxx| 国产亚洲依依| 国产老肥熟xxxx在线观看| av首页在线| 在线播放黄色网址| 国产成人天天5g影院| 国产一级二级三级在线观看| 成年女人在线视频| 欧美色第一页| 中文日本在线观看| 92久久精品| 在线国产小视频| 国产不卡在线| 国产激情网址| 国产精品剧情一区二区在线观看 | 中文av字幕| 国产高清自拍视频在线观看| 最近久乱中文字幕| 国产女呦网站| 黄色毛片在线| 国产在线观看网站| 国产在线激情视频| 日本中文字幕高清视频| 黄色毛片在线看| 国产毛片视频| 国产偷激情在线| 国产福利一区二区在线精品| 国产午夜视频| 国产porn在线| xxx国产精品| 国产永久在线观看| 国产精品18久久久久久久久久| √天堂8资源中文在线| 国产精品人人| 亚洲综合天堂网| 国产美女自拍视频| 国产亚av手机在线观看| 精品久久久久一区二区三区| 亚洲jjzzjjzz在线观看| 另类高清dbsm日本tvav| 国产午夜视频| 性国产高清在线观看| 好看的中文字幕在线播放| 国产一二三在线观看| 亚洲天堂久久久| 国产美女在线看| 中文字幕av高清| 国产永久免费高清在线观看| 国产视频中文字幕在线观看| 亚洲91av| 精品麻豆国产| 国产三级在线免费| 丁香婷婷在线观看|