PHP字符串逆序排列實(shí)現(xiàn)方法小結(jié)【strrev函數(shù),二分法,循環(huán)法,遞歸法】
本文實(shí)例總結(jié)了PHP字符串逆序排列實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
關(guān)于字符串的逆序排列,最簡單的使用PHP函數(shù)strrev()的測試代碼如下:
header('Content-type: text/html; charset=utf-8'); $str = implode('', range(9, 0)); print '< p><strong>Before reversed: </strong>'.$str.'< /p>'; print '< p>< strong>After reversed: < /strong>'.strrev($str).'< /p>'; /* 輸出如下: Before reversed: 9876543210 After reversed: 0123456789 */
如果不用內(nèi)置的PHP函數(shù)strrev(),又該如何實(shí)現(xiàn)呢?這里另外給出了3種方法(二分法、循環(huán)法、遞歸法),但沒有進(jìn)行性能測試。
(PS:這里為了方便大家閱讀代碼,使用了本站在線php代碼格式化工具http://tools.jb51.net/code/jb51_php_format進(jìn)行了格式化處理。)
1、二分法
/** * 二分法實(shí)現(xiàn)字符串逆序排列 * @param string $str 源字符串 * @return string 返回逆序后的字符串 */ function reverse($str='') { $len = strlen($str); //不能使用count或sizeof $mid = floor($len/2); for ($i=0; $i<$mid; $i++) { $temp = $str[$i]; $str[$i] = $str[$len-$i-1]; $str[$len-$i-1] = $temp; } return $str; }
2、循環(huán)法
/** * 循環(huán)實(shí)現(xiàn)對(duì)字符串的逆序排列(效率比二分法低) * @param string $str 源字符串 * @return string 返回逆序后的字符串 */ function reverse($str='') { $result = ''; for ($i=1; $i<=strlen($str); $i++) { $result .= substr($str, -$i, 1); } return $result; }
3、遞歸法
/** * 遞歸實(shí)現(xiàn)對(duì)字符串的逆序排列(效率低) * @param string $str 源字符串 * @return string 返回逆序后的字符串 */ function reverse($str='') { static $result = ''; /* 用堆棧來理解遞歸調(diào)用 */ if (strlen($str) > 0) { reverse(substr($str, 1)); $result .= substr($str, 0, 1); //此句必須放在上一語句之后 } return $result; }
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php排序算法總結(jié)》、《PHP常用遍歷算法與技巧總結(jié)》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- 使用PHP實(shí)現(xiàn)二分查找算法代碼分享
- PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
- php二分法在IP地址查詢中的應(yīng)用
- php二分查找二種實(shí)現(xiàn)示例
- 深入理解PHP幾個(gè)算法:PHP冒泡、PHP二分法、PHP求素?cái)?shù)、PHP乘法表
- php順序查找和二分查找示例
- php 數(shù)組二分法查找函數(shù)代碼
- php數(shù)據(jù)結(jié)構(gòu)與算法(PHP描述) 查找與二分法查找
- php中二分法查找算法實(shí)例分析
- 數(shù)據(jù)結(jié)構(gòu)之利用PHP實(shí)現(xiàn)二分搜索樹
相關(guān)文章
php獲取手機(jī)端的號(hào)碼以及ip地址實(shí)例代碼
這篇文章我們給大家一個(gè)完整的通過php獲取手機(jī)端的號(hào)碼以及ip地址實(shí)例代碼,需要的朋友們可以測試參考下。2018-09-09PHP動(dòng)態(tài)分頁函數(shù),PHP開發(fā)分頁必備啦
PHP動(dòng)態(tài)分頁函數(shù),PHP開發(fā)分頁必備啦。其實(shí)吧,這個(gè)是必用的,不說了,PHP動(dòng)態(tài)分頁函數(shù)還是不錯(cuò),比較簡單吧2011-11-11深入了解 register_globals (附register_globals=off 網(wǎng)站打不開的解決方法)
由于register_globals設(shè)置控制PHP變量訪問范圍,如果開啟會(huì)引起不必要的安全問題,所以這里對(duì)其進(jìn)行了強(qiáng)制關(guān)閉,如果站長的空間不支持,可以采用以下幾種辦法進(jìn)行修改,供廣大站長參考2012-06-06PHP利用ChatGPT實(shí)現(xiàn)輕松創(chuàng)建用戶注冊(cè)頁面
ChatGPT?是?OpenAI?開發(fā)的?GPT語言模型的變體,它是一種大型單向語言模型。本文就來利用ChatGPT創(chuàng)建簡單的用戶注冊(cè)頁面,感興趣的可以了解一下2023-02-02PHP利用APC模塊實(shí)現(xiàn)大文件上傳進(jìn)度條的方法
這篇文章主要介紹了PHP利用APC模塊實(shí)現(xiàn)大文件上傳進(jìn)度條的方法,并分享了相關(guān)配置說明,感興趣的朋友可以學(xué)習(xí)借鑒。2015-10-10PHP 處理TXT文件(打開/關(guān)閉/檢查/讀取)
php寫入txt、php讀取txt,在PHP處理TXT文件時(shí)經(jīng)常會(huì)使用到,本文整理了一些相關(guān)代碼,感興趣的朋友可以參考下哈2013-05-05