翻手算法php,PHP各种常见经典算法总结【排序、查找、翻转等】

本文实例讲述了php各种常见经典算法。分享给大家供大家参考,具体如下:

冒泡排序算法

public function test() {

$arr = array(43, 54, 62, 21, 66, 32, 78, 36, 76, 39);

var_dump($arr);

echo '
';

$arr = $this->bubblesort($arr);

var_dump($arr);

}

public function bubblesort($arr) {

$len = count($arr);

//该层循环控制 需要冒泡的轮数

for ($i = 1; $i < $len; $i++) {

//该层循环用来控制每轮 冒出一个数 需要比较的次数

for ($k = 0; $k < $len - $i; $k++) {

if ($arr[$k] > $arr[$k + 1]) {

$tmp = $arr[$k + 1]; // 声明一个临时变量

$arr[$k + 1] = $arr[$k];

$arr[$k] = $tmp;

}

}

}

return $arr;

}

快速排序

public function quick_sort($arr) {

//先判断是否需要继续进行

$length = count($arr);

if ($length <= 1) {

return $arr;

}

$base_num = $arr[0]; //选择一个标尺 选择第一个元素

//初始化两个数组

$left_array = array(); //小于标尺的

$right_array = array(); //大于标尺的

for ($i = 1; $i < $length; $i++) { //遍历 除了标尺外的所有元素,按照大小关系放入两个数组内

if ($base_num > $arr[$i]) {

//放入左边数组

$left_array[] = $arr[$i];

} else {

//放入右边

$right_array[] = $arr[$i];

}

}

//再分别对 左边 和 右边的数组进行相同的排序处理方式

//递归调用这个函数,并记录结果

$left_array = $this->quick_sort($left_array);

$right_array = $this->quick_sort($right_array);

//合并左边 标尺 右边

return array_merge($left_array, array($base_num), $right_array);

}

public function test() {

$arr = array(4, 3, 1, 2, 8, 9);

var_dump($arr);

echo '
';

$arr = $this->quick_sort($arr);

var_dump($arr);

}

二分查找

public function bin_search($arr, $low, $high, $k) {

if ($low <= $high) {

$mid = intval(($low + $high) / 2);

if ($arr[$mid] == $k) {

return $mid;

} else if ($k < $arr[$mid]) {

return $this->bin_search($arr, $low, $mid - 1, $k);

} else {

return $this->bin_search($arr, $mid + 1, $high, $k);

}

}

return -1;

}

public function test() {

$arr = array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

var_dump($arr);

echo '
';

$arr = $this->bin_search($arr, 0, 8, 4);

var_dump($arr);

}

顺序查找

public function seq_search($arr, $n, $k) {

$array[$n] = $k;

for ($i = 0; $i < $n; $i++) {

if ($arr[$i] == $k) {

break;

}

}

if ($i < $n) {

return $i;

} else {

return -1;

}

}

public function test_suanfa() {

$arr = array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

var_dump($arr);

echo '
';

$arr = $this->seq_search($arr, 4, 4);

var_dump($arr);

}

线性表的删除

public function delete_array_element($array, $i) {

$len = count($array);

for ($j = $i; $j < $len; $j ++) {

if (isset($array[$j + 1])) {

$array[$j] = $array[$j + 1];

}

}

array_pop($array);

return $array;

}

public function test() {

$arr = array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

var_dump($arr);

echo '
';

$arr = $this->delete_array_element($arr, 4);

var_dump($arr);

}

字符串翻转

public function strrev($str) {

$rev_str = '';

if ($str == '') {

return 0;

}

for ($i = (strlen($str) - 1); $i >= 0; $i --) {

$rev_str .= $str[$i];

}

return $rev_str;

}

public function test() {

$arr = 'hellow wolrd';

var_dump($arr);

echo '
';

$arr = $this->strrev($arr);

var_dump($arr);

}

希望与广大网友互动??

点此进行留言吧!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/525858.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php文件上传详解,PHP文件上传实例详解!!!

这篇文章主要介绍了PHP文件上传实例代码&#xff0c;需要的朋友可以参考下首先来看下上传部分的表单代码&#xff1a;文件&#xff1a; 这里有几个要注意的地方&#xff0c;首先看这句&#xff0c;这里我们采用POST方法&#xff0c;个别浏览器还支持PUT方法&#xff0c;当然这需…

php上传商品信息并显示,第37课 thinkphp5添加商品基本信息及通过前置钩子上传商品主图 模型事件(勾子函数)...

[TOC]手册地址:before_insert(新增之前的操作)要实现的功能上传原图片,在新增数据之前生成三张缩略图片,然后再插入数据添加商品基本信息及通过后置钩子上传商品主图思路控制器里调用模型的save()方法保存数据模型里的用前置勾子beforeInsert()保存之前把上传原图片先成三张缩略…

java下标越界的三种处理方式,数组下标越界,该怎么解决

数组下标越界package import_csv;import java.io.BufferedReader;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.IOException;import java.io.InputStreamReader;import java.io.UnsupportedEncodingException;import java.sql.Connect…

commvault备份mysql,备份MySQL数据库的4种方式

备份MySQL数据库的4种方式前言我们试着想一想, 在生产环境中什么最重要&#xff1f;如果我们服务器的硬件坏了可以维修或者换新, 软件问题可以修复或重新安装,但是如果数据没了呢&#xff1f;这可能是最恐怖的事情了吧, 我感觉在生产环境中应该没有什么比数据跟更为重要.那么我…

php $app-run(),Thinkphp 5.x 应用启动 App::run()

在上文加载完配置等一系列工作之后&#xff0c;进入App::run()&#xff0c;在run()方法中&#xff0c;首先通过自动加载机制拿到 Request 的一个实例接着 $config self::initCommon()初始化公共配置&#xff0c;先是 addNamespace 添加app当前所在的命名空间&#xff0c;然后 …

php react-native,React-Native+Mobx实现商城APP

这次给大家带来React-NativeMobx实现商城APP&#xff0c;React-NativeMobx实现商城APP的注意事项有哪些&#xff0c;下面就是实战案例&#xff0c;一起来看一下。最近一直在学习微信小程序&#xff0c;在学习过程中&#xff0c;看到了 wxapp-mall这个微信小程序的项目&#xff…

mysql 流程控制语句,mysql PL(procedure language)流程控制语句

在MySQL中&#xff0c;常见的过程式SQL语句可以用在存储体中。其中包括IF语句、CASE语句、LOOP语句、WHILE语句、ITERATE语句和LEAVE语句&#xff0c;它们可以进行流程控制。IF语句相当于Java中的if()...else if()...else...CASE语句相当于Java中的switch()...case A:...break;…

mysql 空闲几分钟速度变慢,MYSQL 运作一小段时间后,速度变得奇慢。而CPU基本空闲状态...

当前位置:我的异常网 MySQL MYSQL 运作一小段时间后&#xff0c;速度变得奇慢。而CPU基本MYSQL 运作一小段时间后&#xff0c;速度变得奇慢。而CPU基本空闲状态www.myexceptions.net 网友分享于&#xff1a;2015-08-26 浏览&#xff1a;11次MYSQL 运行一小段时间后&#xff…

matlab axis 用法,MATLAB中regionprops的用法

Matlab图像处理函数&#xff1a;regionprops这里给出在Matlab图像处理工具箱中非常重要的一个图像分析函数&#xff1a;regionprops。顾名思义&#xff1a;它的用途是get the properties of region&#xff0c;即用来度量图像区域属性的函数。语法STATS regionprops(L,propert…

emqx配置mysql认证,emqx使用mysql完成用户密码验证和ACL鉴权

emqx使用mysql完成用户密码验证和ACL鉴权emqx使用mysql完成用户密码验证和ACL鉴权摘要&#xff1a;前几篇博客介绍的是使用配置文件配置了ACL和客户端用户名密码配置实现生产环境下的安全登录和权限控制&#xff0c;各项配置比较繁琐&#xff0c;修改起来比较麻烦&#xff0c;下…

MATLAB课程表分配问题,求助matlab大神,学校的课程安排太骚了,我们压根就不用学matlab...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼上了MATLAB&#xff0c;可是对数学完全不感兴趣。老师弄了个作业&#xff0c;代码附件了。求大佬帮忙理解原理后简单做一个不一样的过程的程序。帮忙注释一下代码。(一开始忘记下载要币了。不好意思)两个.m文件&#xff0c;需要放一…

php时间转分钟前,PHP把时间转换成几分钟前几小时前几天前

现在很多网站将时间的显示都变得比较人性化&#xff0c;今天项目有一个也需要在对应的资讯后面显示为几分钟前、几小时前&#xff0c;接下来吾爱编程为大家分享一下PHP把时间转换成几分钟前、几小时前几天前的方法&#xff0c;有需要的小伙伴可以参考一下&#xff1a;1、项目需…

emlog_toolkit.php,emlog 4.0版本IIS6下伪静态划定规矩

emlog默许不能生成静态文件&#xff0c;不过彷佛有生成静态页面的相干插件&#xff0c;该插件博客吧先不研讨&#xff0c;本日博客簿要引见的是emlog 4.0版本在IIS6环境下的伪静态划定规矩&#xff0c;人人都晓得&#xff0c;经由过程伪静态能够让博客文章网址变得对搜索引擎越…

php如何封装数组,PHP数组转对象 对象转数组封装类

代码如下/*** 数组 转 对象** param array $arr 数组* return object*/function array_to_object($arr) {if (gettype($arr) ! array) {return;}foreach ($arr as $k > $v) {if (gettype($v) array || getType($v) object) {$arr[$k] (object)array_to_object($v);}}retu…

api.php phpcms,phpcms程序api怎么写接口

易站通&#xff0c;带你玩转PHPCMS建站程序&#xff0c;让你更快的熟悉该程序下面让我们来学习吧phpcms api怎么写接口&#xff1f;最近自己开发了一套crm系统&#xff0c;想着如果将来能卖出去&#xff0c;能不能再界面动态调用自己网站的推荐信息&#xff0c;算是一种广告吧&…

oracle修改窗口字体大小,jQuery之字体大小的设置方法

先获取字体大小&#xff0c;进行处理。再将修改的值保存。slice() 方法可从已有的数组中返回选定的元素。arrayObject.slice(start,end)。start 必需。规定从何处开始选取。如果是负数&#xff0c;那么它规定从数组尾部开始算起的位置。也就是说&#xff0c;-1 指最后一个元素&…

oracle 删除表 索引也会删除吗,Oracle 删除当前用户下所有的表、索引、序列

通过下面语句可以得到要删除Oracle的所有表、索引、序列... 的语句select drop table || table_name ||;||chr(13)||chr(10) from user_tables; --delete tablesselect drop view || view_name||;||chr(13)||chr(10) from user_views; --delete viewsselect drop sequence …

基于Java、Kafka、ElasticSearch的搜索框架的设计与实现

Jkes是一个基于Java、Kafka、ElasticSearch的搜索框架。Jkes提供了注解驱动的JPA风格的对象/文档映射&#xff0c;使用rest api用于文档搜索。项目主页&#xff1a;https://github.com/chaokunyang/jkes安装可以参考jkes-integration-test项目快速掌握jkes框架的使用方法。jkes…

Docker是传统的应用发布管理的终结者么?

译者注&#xff1a;使用Docker能真正改善传统的应用发布管理中遇到的问题么&#xff1f;以下是译文&#xff1a;自从2013年发布以来&#xff0c;Docker已经成为每一个操作管理者眼中的最爱。如果你一直与世隔绝&#xff0c;这里恰恰是你错过的部分。Docker是在一个操作环境地址…

基于Mesos/Docker构建数据处理平台

本文深入介绍了去哪儿网利用Mesos和Docker构建私有云服务的全过程&#xff0c;分享了从无状态应用向有状态应用逐步过度的经验与心得。平台概览2014年下半年左右&#xff0c;去哪儿完成了有关构建私有云服务的技术调研&#xff0c;并最终拍定了Docker/Mesos这一方案。下图1展示…