探讨PHP字符串颠倒顺序的实现方法

我们如何在PHP编码中实现字符串顺序的颠倒呢?在这篇文章中,我们将为大家详细介绍有关PHP字符串颠倒顺序的实现方法,希望对大家有所帮助。

首先,php自带了一个字符串颠倒顺序的函数。

PHP字符串颠倒顺序代码:

 
 
 
  1. $str = 'To Change The template';
  2. echo strrev($str);
  3. // 结果:etalpmet ehT egnahC oT  

其次,使用递归函数实现。当然效率很低!PHP字符串颠倒顺序代码:

 
 
 
  1. function reverse_r($str)
  2.  { if (strlen($str) > 0)
  3. { reverse_r(substr($str, 1)); 
  4. echo substr($str, 0, 1); 
  5. return;}echo reverse_r($str);   

第三,使用循环实现,效率有很大的提高。PHP字符串颠倒顺序代码:

 
 
 
  1. /** * 利用循环实现字符串逆序排列 */ 
  2. function reverse_i($str)
  3. { for ($i = 1; $i < = strlen($str); $i++)
  4. { echo substr($str, -$i, 1); } return; 
  5. }
  6. echo reverse_i($str);   

***,使用二分法实现,效率有更大的提高。PHP字符串颠倒顺序代码:

 
 
 
  1. /** * 使用二分法来实现字符串颠倒顺序。 */ 
  2. function reverse_a($str)
  3. { $forNum = ceil(strlen($str)/2); 
  4. $strLen = strlen($str); 
  5. for ( $i = 1; $i < = $forNum; $i++) 
  6. { if($i <= $strLen-$i)
  7. { $tmp = $str[$i-1]; $str[$i-1] = 
    $str[$strLen-$i]; $str[$strLen-$i]= $tmp; 
  8. return $str; }
  9. // 注:其实按照二分法来实现,理论上效率会提升一半,但是这个涉及
  10. //到数组的指针操作,实际效率会怎样?
    难说。echo "二分实现:\t",reverse_a($str);  

#t#***一种PHP字符串颠倒顺序的方法涉及到三个知识点:

1. ceil()函数:进一法取整。如:5/4=1.25,ceil(5/4)=2,不管小数位是否大于0.5,均进一取整。

2. 字符串当成数组访问,如$str[0],$str[1]…可以访问字符串$str的***个字符、第二个字符…

3. 二分法。PHP字符串颠倒顺序的方法3需要循环的次数是字符串的长度,而方法4则是字符串长度的一半,所以效率会提高一倍(理论上)。

网站标题:探讨PHP字符串颠倒顺序的实现方法
分享URL:http://www.shufengxianlan.com/qtweb/news42/319792.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联