设为首页
收藏本站
用户名
Email
自动登录
找回密码
密码
登录
立即注册
只需一步,快速开始
快捷导航
登录
注册
论坛首页
BBS
建站模版
微站设计
虚拟主机
企业邮箱
博客日志
Blog
搜索
搜索
搜索
热搜
长春
优惠
活动
做网站
本版
帖子
用户
本版
帖子
用户
请
登录
后使用快捷导航
没有帐号?
立即注册
道具
勋章
任务
留言板
设置
我的收藏
退出
时时商务社区
»
论坛首页
›
建站资源
›
建站技术
›
PHP字符串逆序排列实现方法小结【strrev函数,二分法, ...
返回列表
查看:
988
|
回复:
0
PHP字符串逆序排列实现方法小结【strrev函数,二分法,循环法,递归法】
[复制链接]
wx_pylelnL4
当前离线
积分
7532
2536
主题
2536
帖子
7532
积分
论坛元老
论坛元老, 积分 7532, 距离下一级还需 9992467 积分
论坛元老, 积分 7532, 距离下一级还需 9992467 积分
积分
7532
发消息
电梯直达
楼主
发表于 2018-2-14 05:28:52
|
只看该作者
|
倒序浏览
|
阅读模式
本文实例总结了PHP字符串逆序排列实现方法。分享给大家供大家参考,具体如下:
关于字符串的逆序排列,最简单的使用PHP函数strrev()的测试代码如下:
header('Content-type: text/html; charset=utf-8');
$str = implode('', range(9, 0));
print '
Before reversed:
'.$str.'';
print 'After reversed: '.strrev($str).'';
/*
输出如下:
Before reversed: 9876543210
After reversed: 0123456789
*/
如果不用内置的PHP函数strrev(),又该如何实现呢?这里另外给出了3种方法(二分法、循环法、递归法),但没有进行性能测试。
(
PS
:这里为了方便大家阅读代码,使用了本站在线php代码格式化工具
http://tools.jb51.net/code/jb51_php_format
进行了格式化处理。)
1、二分法
/**
* 二分法实现字符串逆序排列
* @param string $str 源字符串
* @return string 返回逆序后的字符串
*/
function reverse($str='') {
$len = strlen($str);
//不能使用count或sizeof
$mid = floor($len/2);
for ($i=0; $i
2、循环法
/**
* 循环实现对字符串的逆序排列(效率比二分法低)
* @param string $str 源字符串
* @return string 返回逆序后的字符串
*/
function reverse($str='') {
$result = '';
for ($i=1; $i
3、递归法
/**
* 递归实现对字符串的逆序排列(效率低)
* @param string $str 源字符串
* @return string 返回逆序后的字符串
*/
function reverse($str='') {
static $result = '';
/* 用堆栈来理解递归调用 */
if (strlen($str) > 0) {
reverse(substr($str, 1));
$result .= substr($str, 0, 1);
//此句必须放在上一语句之后
}
return $result;
}
更多关于PHP相关内容感兴趣的读者可查看本站专题:《
PHP数据结构与算法教程
》、《
php程序设计算法总结
》、《
php排序算法总结
》、《
PHP常用遍历算法与技巧总结
》、《
PHP数学运算技巧总结
》、《
PHP数组(Array)操作技巧大全
》、《
php字符串(string)用法总结
》及《
php常见数据库操作技巧汇总
》
希望本文所述对大家PHP程序设计有所帮助。
您可能感兴趣的文章:
php二分法在IP地址查询中的应用
php 数组二分法查找函数代码
php数据结构与算法(PHP描述) 查找与二分法查找
解析php二分法查找数组是否包含某一元素
深入理解PHP几个算法
HP冒泡、PHP二分法、PHP求素数、PHP乘法表
PHP常用的排序和查找算法
php中二分法查找算法实例分析
PHP实现的折半查询算法示例
PHP基于二分法实现数组查找功能示例【循环与递归算法】
分享到:
QQ好友和群
QQ空间
腾讯微博
腾讯朋友
收藏
0
回复
使用道具
举报
返回列表
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
用户反馈
客户端