PHP常用排序算法实例小结【基本排序,冒泡排序,快速排序,插入排序】
代码如下 | 复制代码 |
classbevin{ public$public='public' private$private='private' protected$protected='protected' //final $final = 'final' static$static='static' function__construct(){ $this->protected='change private' } publicfunctionsetValue($a){ self::$static=$a; } publicfunctiongetValue(){ echo$this->private; } function__destruct(){ echo'asdfsadf' } } classpaixu { // 基本排序 publicfunctiont_sortArray($array) { if(is_array($array) &&count($array)>1) { for($i=0;$i<count($array);$i++) { for($j=($i+1);$j<count($array);$j++) { $temp=$array[$i]; if($array[$j]<$array[$i]) { $array[$i] =$array[$j]; $array[$j] =$temp; } } } return$array; }else{ return$array; } } // 冒泡排序 publicfunctionc_sortArray($array) { if(!is_array($array) ||count($array)<=1){return$array; } $status= false; foreach($arrayas$key=>$v) { if($key>0) { if($array[$key-1]>$array[$key]) { $array[$key] =$array[$key-1]; $array[$key-1] =$v; $status= true; } } } if($status) { return$this->c_sortArray($array); }else{ return$array; } } // 快速排序 publicfunctionv_sortArray($array) { if(!is_array($array) ||count($array)<=1){return$array; } if(count($array)>2) { $m=$array[floor(count($array)/2)+1]; }else{ if($array[0]>$array[1]) { $temp=$array[0]; $array[0] =$array[1]; $array[1] =$temp; } return$array; } $leftarray=array(); $rightarray=array(); foreach($arrayas$key=>$v) { if($v>$m) { $rightarray[] =$v; } if($v<$m) { $leftarray[] =$v; } if($v==$m) { $mid[] =$v; } } $nleftarray=$this->v_sortArray($leftarray); $nrightarray=$this->v_sortArray($rightarray); returnarray_merge($nleftarray,$mid,$nrightarray); } // 直接插入排序 publicfunctioni_sortArray($array) { if(!is_array($array) ||count($array)<=1){return$array; } $newarray=array($array[0]); $temp= 0; foreach($arrayas$k=>$v) { if($k>0) { if($v>=$newarray[count($newarray)-1]) { $newarray[] =$v; }else{ foreach($newarrayas$nk=>$nv) { if($v<$nv) { $temparray=array(); foreach($newarrayas$ck=>$cv) { if($ck<$nk) { $temparray[$ck] =$cv; }elseif($ck==$nk) { $temparray[$ck] =$v; $temparray[($ck+1)] =$cv; }else{ $temparray[($ck+1)] =$cv; } } $newarray=$temparray; break; } } } } } return$newarray; } } $bevin=newpaixu; $array=array(5,4,5,4,4,5,5,5,5,5); $v=$bevin->t_sortArray($array); print_r($v); $v=$bevin->c_sortArray($array); print_r($v); $v=$bevin->v_sortArray($array); print_r($v); $v=$bevin->i_sortArray($array); print_r($v); |
运行结果:
代码如下 | 复制代码 |
Array ( [0] => 4 [1] => 4 [2] => 4 [3] => 5 [4] => 5 [5] => 5 [6] => 5 [7] => 5 [8] => 5 [9] => 5 ) Array ( [0] => 4 [1] => 4 [2] => 4 [3] => 5 [4] => 5 [5] => 5 [6] => 5 [7] => 5 [8] => 5 [9] => 5 ) Array ( [0] => 4 [1] => 4 [2] => 4 [3] => 5 [4] => 5 [5] => 5 [6] => 5 [7] => 5 [8] => 5 [9] => 5 ) Array ( [0] => 4 [1] => 4 [2] => 4 [3] => 5 [4] => 5 [5] => 5 [6] => 5 [7] => 5 [8] => 5 [9] => 5 ) |
代码如下 | 复制代码 |
filename ='img/test.jpg' $all_type=array( "jpg" =>array("create"=>"ImageCreateFromjpeg","output"=>"imagejpeg" ,"exn"=>".jpg"), "gif" =>array("create"=>"ImageCreateFromGIF","output"=>"imagegif" ,"exn"=>".gif"), "jpeg" =>array("create"=>"ImageCreateFromjpeg","output"=>"imagejpeg" ,"exn"=>".jpg"), "png" =>array("create"=>"imagecreatefrompng","output"=>"imagepng" ,"exn"=>".png"), "wbmp" =>array("create"=>"imagecreatefromwbmp","output"=>"image2wbmp","exn"=>".wbmp") ); $imgtype=getimagesize($filename); $width=$imgtype[0]; $height=$imgtype[1]; $type=str_replace('image/','',$imgtype['mime']); $func_create=$all_type[$type]['create']; $func_output=$all_type[$type]['output']; $x=$y=0; if(($width* 100)>($height* 120)) { $newwidth=ceil($height* 120/100); $newheight=$height; $x= ($width-$newwidth)/2; } elseif(($width* 100)<($height* 120)) { $newheight=ceil($width* 100/120); $newwidth=$width; $y= ($height-$newheight)/2; } else { $newheight=$height; $newwidth=$width; } // Load $thumb= imagecreatetruecolor($newwidth,$newheight); $source=$func_create($filename); // Resize imagecopyresized($thumb,$source, 0, 0, 0, 0,$newwidth,$newheight,$newwidth,$newheight); // Output $func_output($thumb,'a.jpeg'); |
PHPCMS手机站伪静态怎么设置?本文详细介绍了PHPCMS手机站伪静态设置详细教程非常实用,有兴趣的同学快来看看吧!
1、打开/phpcms/modules/wap/functions/global.func.php
找到里面的这两个函数,如下图所示的注释掉的那行代码,在下面加入一行代码。
代码如下 | 复制代码 |
functionlist_url($typeid) { #returnWAP_SITEURL."&a=lists&typeid=$typeid"; return"/list-$typeid".'.html' } functionshow_url($catid,$id,$typeid='') { global$WAP; if($typeid=='') { $types= getcache('wap_type','wap'); foreach($typesas$type) { if($type['cat']==$catid) { $typeid=$type['typeid']; break; } } } #returnWAP_SITEURL."&a=show&catid=$catid&typeid=$typeid&id=$id"; return"/show-$catid-$typeid-$id-1".'.html' } |
2、打开/phpcms/modules/wap/index.php
找到第59行,如下图所示的注释掉的那行代码,在下面加入一行代码。
代码如下 | 复制代码 |
#define('URLRULE','index.php?m=wap&c=index&a=lists&typeid={$typeid}~index.php?m=wap&c=index&a=lists&typeid={$typeid}&page={$page}'); define('URLRULE','list-{$typeid}.html~list-{$typeid}-{$page}.html'); |
3、添加伪静态规则
我使用的是apache服务器,把apache服务器设置支持.htaccess文件,在网站根目录创建.htaccess文件,在里面添加代码:
代码如下 | 复制代码 |
RewriteEngine On RewriteRule ^list-([0-9]+)-([0-9]+) index.php?&a=lists&typeid=$1&page=$2 RewriteRule ^list-([0-9]+) index.php?&a=lists&typeid=$1; RewriteRule ^show-([0-9]+)-([0-9]+)-([0-9]+) index.php?a=show&catid=$1&typeid=$2&id=$3; |
这样,phpcms手机站就变成伪静态了。
.htaccess如何设置和创建可自行百度一下,方法都比较简单,这里就不细说了。
如果是nginx服务器,重写规则这样写:
代码如下 | 复制代码 |
rewrite ^/list-([0-9]+).html /index.php?&a=lists&typeid=$1last; rewrite ^/show-([0-9]+)-([0-9]+)-([0-9]+)-1.html /index.php?a=show&catid=$1&typeid=$2&id=$3last; |
先简单的介绍一下单例模式。单例模式就是在应用程序中保持某一个类实例只存在一个,而且不可以受外部环境的影响而生成这个类的第二个实例。它的优点,实际点见,如果在WEB开发中,保持单一个数据操作类实例的存在,可以减少不必要的多余连接数据库资源的消耗,对于大型的软件开发来说,可以使用单例来维持程序的状态,使不同操作实现同步,因为单例一直占据内存,而从不会有副本。
而对于PHP,使用单例最常用的场合莫过于写一个数据库操作类。不过在PHP中实现单例,有以下规则:
1)单例类必须拥有一个现式声明的构造函数,并且是私有的。
2)单例类必须有一个静态变量来存储类的实例,这样可以保持这个单例类就只有那么一个实例。
3)单例类必须提供一个静态方法,供其他所有的对象应用这个单例。
为什么要满足以上三个条件呢:
1)因为单例类在整个应用程序运行时,只能被创造一次,而且这种创造是不是通过外部调用而完成,而是自身完成。所以单例类是自己实例化自己,所以其构造函数必须是私有。任何其他外部对象都不可以再次构造一个单例类的副本。
2)因为单例类只能够自己实例化自己,而又要为所有外部应用提供自己的实例,所以类内部必须有一个可供外界访问,而又是唯一不变的访问存储对象点,所以要提供一个静态变量去存储单例类自己实例化自己的那个实例对象。
3)因为单例类的构造函数是私有的,所以单例类必须提供一个外部接口供外部环境调用单例类,所以必须有一个静态方法,它可以初始化单例类或者返回单例类的对象的引用。
一个简单的例子:
代码如下 | 复制代码 |
classDB{ private$_link; // 保持单例类的静态变量 static$_instance; // 私有的构造函数 privatefunction__construct(){ $this->_link = @mysqli_connect(__HOST__, __USER__, __PASSWORD__, __DATABASE__); if(! ($this->_link)){ echo'Something wrong occurs on the database connection!' } } // 防止单例类被克隆 privatefunction__clone(){} // 外界访问单例类实例的接口 publicstaticfunctiongetInstance(){ if(! (self::$_instanceinstanceofself)){ self::$_instance=newself(); } returnself::$_instance; } } |
注意,以上定义的一个 __clone() 函数,防止单例类对象被克隆。
以下也是一个简单的数据库操作类的单例,供参考:
代码如下 | 复制代码 |
classDB { /** * the database connection * @var resource * @access private */ private$_link; /** * the static instance of single db * @var object * @access static */ static$_instance; /** * construct the single object * @return null * @access private */ privatefunction__construct(){ $this->_link = @mysqli_connect(__HOST__, __USER__, __PASSWORD__, __DATABASE__); if(! ($this->_link)){ echo'Something wrong occurs on the database connection!' } } /** * empty clone * @return null * @access private */ privatefunction__clone(){} /** * for other object to get the instance of db * @return self::instance * @access public */ publicstaticfunctiongetInstance(){ if(! (self::$_instanceinstanceofself)){ self::$_instance=newself(); } returnself::$_instance; } /** * query * @param sql string * @param message string * @return resource * @access public */ publicfunctionquery($sql,$message){ $result= @mysqli_query($this->$_link,$sql)ordie($message. mysqli_error($this->$_link)); return$result; } /** * mysqli_num_rows * @param result resource * @return int * @access public */ publicfunctionnum($result){ return@mysqli_num_rows($result); } /** * mysqli_fetch_array * @param result resource * @return array * @access public */ publicfunctionfetchArr($result){ return@mysqli_fetch_array($result); } /** * mysqli_insert_id * @return int * @access public */ publicfunctionlast_id(){ return@mysqli_insert_id($this->_link); } /** * close the database connection * @param result resource * @return null * @access public */ publicfunctionclose(){ @mysqli_close($this->_link); } /** * fetch once result from the specific sql query * @param sql string * @param message string * @return array * @access public */ publicfunctionfetchArrOnce($sql,$message){ $result=$this->query($sql,$message); $row=$this->fetchArr($result); return$row; } /** * fetch all results from the specific sql query * @param sql string * @param message string * @return array * @access public */ publicfunctionfetchArrMore($sql,$message){ $result=$this->query($sql,$message); $moreRow=array(); while($row=$this->fetchArr($result)){ $moreRow[] =$row; } return$moreRow; } /** * fetch the number of results from the specific sql query * @param sql string * @param message string * @return array * @access public */ publicfunctionfetchNum($sql,$message){ $result=$this->query($sql,$message); $resultNum=$this->num($result); return$resultNum; } /** * mysqli_prepare * @param sql string * @return stmt object * @access public */ publicfunctionprepare($sql){ return@mysqli_prepare($this->_link,$sql); } /** * mysqli_stmt_execute * @param stmt object * @param message string * @return bool * @access public */ publicfunctionstmt_execute($stmt,$message){ @mysqli_stmt_execute($stmt)ordie($message. mysqli_error($this->_link)); } } |
使用:
代码如下 | 复制代码 |
define("__HOST__","localhost"); define("__USER__","root"); define("__PASSWORD__",""); define("__DATABASE__","eee"); $db= DB::getInstance(); |
相关文章
- 作者:Sabine 【导读】本文介绍了C#的四种排序算法:冒泡排序、选择排序、插入排序和希尔排序 冒泡排序 using System; namespace BubbleSorter { public class Bubb...2020-06-25
- 这篇文章主要为大家详细介绍了js实现数组冒泡排序、快速排序的原理,感兴趣的小伙伴们可以参考一下...2016-03-10
图文详解Heap Sort堆排序算法及JavaScript的代码实现
这篇文章以图文详解Heap Sort堆排序算法及JavaScript的代码实现,堆排序算法基于类二叉树的堆数据结构,需要的朋友可以参考下...2016-05-05- 本文给大家汇总介绍了几个个人收藏的JavaScript实现冒泡排序的代码,都是非常的不错,有需要的小伙伴可以参考下...2016-06-12
- 这篇文章主要为大家详细介绍了C/C++实现八大排序算法汇总,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-04-25
- 这篇文章主要介绍了c# 冒泡排序算法,需要的朋友可以参考下...2020-06-25
- 这篇文章主要介绍了GOLANG版的冒泡排序和快速排序分享,需要的朋友可以参考下...2020-05-11
- 这篇文章主要介绍了C语言对数组元素进行冒泡排序的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-04
- 这篇文章主要介绍了C#快速排序算法,实例分析了C#排序方法的相关技巧,非常具有实用价值,需要的朋友可以参考下...2020-06-25
- 这篇文章主要介绍了C语言演示对归并排序算法的优化实现,归并排序的最差时间复杂度为(n\log n),最优时间复杂为(n),存在可以改进的空间,需要的朋友可以参考下...2020-04-25
- 冒泡排序和快速排序算法在开发应用中各有优点了,下面我们来看几个关于php排序的几个例子。 使用PHP描述冒泡排序和快速排序算法,对象可以是一个数组。 使用PHP描...2016-11-25
- 这篇文章主要为大家详细介绍了C++排序算法之插入排序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-04-25
- c语言实现插入排序、冒泡排序、选择排序、快速排序、堆排序、归并排序、希尔排序示例,需要的朋友可以参考下...2020-04-25
- 冒泡排序我们排序算法中的许多中的其中一样了,这里我们一起来了解一下php实现冒泡排序实现方法与原理,具体如下。 一个程序应包括: 对数据的描述:在程序中要指定数...2016-11-25
- 冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。...2020-04-25
- 这篇文章主要介绍了C语言对磁盘文件进行快速排序简单实例的相关资料,需要的朋友可以参考下...2020-04-25
- 这篇文章主要介绍了php项目开发中用到的快速排序算法,结合实例形式详细分析了php快速排序的原理与使用方法,需要的朋友可以参考下...2016-07-02
stl常用算法(Algorithms)介绍(stl排序算法、非变序型队列)
这篇文章主要介绍了stl常用算法(Algorithms)介绍(stl排序算法、非变序型队列),需要的朋友可以参考下...2020-04-25- 这篇文章主要介绍了C#使用委托实现的快速排序算法,实例分析了C#委托机制与快速排序算法的实现技巧,需要的朋友可以参考下...2020-06-25
- function quickSort(&$data, $beg, $end) 02 { 03 if ($end > $beg) { 04 $piv = $data[$beg]; 05 $k = $beg + 1; 06 $r = $end; 07 while ($k < $r) { 08 if...2016-11-25