PHP面試題(一)

來源:互聯網
上載者:User
前言快開始校招了,我應聘的職位以php和c開發為主,最近也會從網上找幾套php面試的題目,親自做一遍並且記錄一下基礎題 1.回答
<?php$str1 = null;$str2 = false;echo $str1 == $str2 ? '相等' : '不相等';

相等.

<?php$str1 = '';$str2 = 0;echo $str1 == $str2 ? '相等' : '不相等';

相等 

<?php$str1 = 0;$str2 = '0';echo $str1 === $str2 ? '相等' : '不相等';

不相等解釋:原因是在PHP中變數是以C語言的結構體來儲存的,Null 字元串和null,false都是以值為0儲存的,其中這個結構體有個zend_uchar type;這樣的成員變數,他是用來儲存變數的類型的,而Null 字元串的類型是string,NULL的類型是NULL,false是boolean
2.寫出如下程式的輸出結果

<?php$a1 = null;$a2 = false;$a3 = 0;$a4 = '';$a5 = '0';$a6 = 'null';$a7 = array();$a8 = array(array());echo empty($a1) ? 'true ' : 'false ';echo empty($a2) ? 'true ' : 'false ';echo empty($a3) ? 'true ' : 'false ';echo empty($a4) ? 'true ' : 'false ';echo empty($a5) ? 'true ' : 'false ';echo empty($a6) ? 'true ' : 'false ';echo empty($a7) ? 'true ' : 'false ';echo empty($a8) ? 'true ' : 'false ';?>

true true true true true false true false
解釋:empty的判斷更加嚴格

3.寫出如下程式的輸出結果

<?php$test = 'aaaaaa';$abc = & $test;unset($abc);echo $abc;?>

aaaaaa

解釋:引用傳遞,'aaaaaa'佔用記憶體的引用數不為0,因此記憶體沒有被釋放,輸出為aaaaaa 4.寫出如下程式的輸出結果
<?php$count = 5;function get_count(){    static $count = 0;        return $count ++;}echo $count;++ $count;echo get_count();echo get_count();?>

501解釋:基本的變數範圍和靜態變數的特性5.寫出如下程式的輸出結果

<?php$GLOBALS['var1'] = 5;$var2 = 1;function get_value(){    global $var2;    $var1 = 0;        return $var2 ++;}get_value();echo $var1;echo $var2;

52解釋: global $var2使得$var2使用的是全域變數$var1沒有使用global或者$GLOBALS['var1']來聲明為全域變數,因此為局部變數,對局部變數的修改不會影響到全域變數6.寫出如下程式的輸出結果

<?phpfunction get_arr($arr){    unset($arr[0]);}$arr1 = array(1, 2);$arr2 = array(1, 2);get_arr(&$arr1);get_arr($arr2);echo count($arr1);echo count($arr2);

12解釋:區分值傳遞和引用傳遞7.使用5種以上的方式擷取一個檔案的副檔名要求: dir/upload.image.jpg, 找出.jpg或者jpg

<?php/** * 五種方式擷取指定路徑的副檔名 */$str = "dir/upload.image.jpg";function one ($str){    $arr = explode('.', $str);    $count = count($arr);        return $arr[$count - 1];}function two ($str){    $len = strlen($str);        for ($i = $len - 1, $name = ''; $str[$i] != '.'; $i --) {        $name .= $str[$i];    }    $name = strrev($name);        return $name;}function three($str){    $path = pathinfo($str);        return $path['extension'];} function four($str){    $arr = explode('.', $str);        return array_pop($arr);}function five($str){    $start = strrpos($str, '.');        return substr($str, $start + 1);}echo one($str);echo "<br>";echo two($str);echo "<br>";echo three($str);echo "<br>";echo four($str);echo "<br>";echo five($str);echo "<br>";
演算法題 1.使用PHP描述冒泡排序和快速排序,對象可以是一個數組
<?php/** * 冒泡排序演算法實現(從小到大) */function maopaoSort (&$array){    $count = count($array);        for ($i = 0; $i < $count - 1; $i ++) {        for ($j = 0; $j < $count - $i - 1; $j ++) {            if ($array[$j] > $array[$j + 1]) {                $tmp = $array[$j];                $array[$j] = $array[$j + 1];                $array[$j + 1] = $tmp;            }        }    }}/** * 快速排序 */function pivotParation (&$array, $start, $end){    $stand = $array[$start];        while ($start < $end) {        while ($start < $end && $array[$end] >= $stand) {            $end --;        }        if ($start < $end) {            $array[$start ++] = $array[$end];        }                while ($start < $end && $array[$start] <= $stand) {            $start ++;        }        if ($start < $end) {            $array[$end --] = $array[$start];        }    }        $array[$start] = $stand;        return $start;}function quickSort (&$array, $begin, $end){    if ($begin < $end) {        $pivot = pivotParation($array, $begin, $end);        quickSort($array, $begin, $pivot - 1);        quickSort($array, $pivot + 1, $end);    }}$arr = array(        5,        1,        3,        2,        19,        11,        25,        12,        100,        10000,        12);// 冒泡排序maopaoSort($arr);print_r($arr);echo "<br>";// 快速排序$count = count($arr);quickSort($arr, 0, $count - 1);print_r($arr);
2.使用php描述順序尋找和二分尋找
<?php/** * 順序尋找 */function seqSearch ($arr, $needle){    for ($i = 0, $len = count($arr); $i < $len; $i ++) {        if ($arr[$i] == $needle) {            return $i;        }    }    return - 1;}/** * 二分尋找 */function midSearch ($arr, $start, $end, $needle){    while ($start <= $end) {        $mid = (int)($start + ($end - $start) / 2); // 防止超出整數表示範圍                if ($arr[$mid] == $needle) {            return $mid;        } else if ($arr[$mid] > $needle) {            $end = $mid - 1;        } else {            $start = $mid + 1;        }    }        return - 1;}$arr = array(        1,        2,        3,        4,        5,        6,        7,        8,        9,        10);$needle = 5;echo seqSearch($arr, $needle);echo "<br>";echo midSearch($arr, 0, count($arr) - 1, $needle);

3.寫一個二維數組排序演算法函數,能夠具有通用性,可以調用php內建函數

/** * Description:擷取中樞點的位置 * * @param array $array             * @param int $left             * @param int $right             * @param string $field             * @return int */function fetchArrayPivot (&$array, $left, $right, $field){    // 基準定義    $stand = $array[$left];        // 遍曆數組    while ($left < $right) {        while ($left < $right && $array[$right][$field] >= $stand[$field]) {            $right --;        }        if ($left < $right) {            $array[$left ++] = $array[$right];        }                while ($left < $right && $array[$left][$field] <= $stand[$field]) {            $left ++;        }        if ($left < $right) {            $array[$right --] = $array[$left];        }    }        // 擷取中樞點位置    $array[$left] = $stand;        return $left;}/** * Description:快速排序主程式 * * @param array $array             * @param int $begin             * @param int $end             * @param string $field             */function quickSort (&$array, $begin, $end, $field){    // 變數定義    $pivot = null;        if ($begin < $end) {        $pivot = fetchArrayPivot($array, $begin, $end, $field);        quickSort($array, $begin, $pivot - 1, $field);        quickSort($array, $pivot + 1, $end, $field);    }}

利用快排的思想,增加一個field參數

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.