算法-PHP实现八大算法


交换函数:注意要按引用传递,否则无法真正交换两个数的值
function exchange(&$a, &$b){
$temp = $a;
$a = $b;
$b = $temp;
}
1、直接插入算法
//第一种实现
function insert_sort($arr){
for ($i = 0; $i < count($arr)-1; $i++){
for($j = $i+1; $j > 0; $j--){
if($arr[$j] > $arr[$j-1]){
exchage($arr[$j], $arr[$j-1]);
}
}
}
return $arr;
}
//第二种实现
function insert_sort($arr){
for ($i = 0; $i < count($arr)-1; $i++){
$j = $i + 1;
while($j > 0){
if($arr[$j] > $arr[$j-1]){
exchage($arr[$j], $arr[$j-1]);
}
$j--;
}
}
return $arr;
}
2、希尔排序算法【暂缺】
3、直接选择排序算法
function select_sort($arr){
for($i = 0; $i < count($arr); $i++){
$key = $arr[$i];
$n = $i;
for($j = $i+1; $j < count($arr); $j++){
if($key > $arr[$j]){
$key = $arr[$j];
$n = $j;
}
}
$arr[$n] = $arr[$i];
$arr[$i] = $key;
}
return $arr;
}
4、堆排序算法【暂缺】
5、冒泡排序算法
//第一种
function bubble_sort($arr){
for($i = 0; $i < count($arr)-1; $i++){
for($j = count($arr)-1; $j > $i; $j--){
if($arr[$j-1] < $arr[$j]){
exchage($arr[$j], $arr[$j-1]);
}
}
}
return $arr;
}
//第二种
function bubble_sort($arr){
for($i = 0; $i < count($arr)-1; $i++){
$j = 0;
while($j < count($arr)-1-$i){
if($arr[$j] < $arr[$j+1]){
exchage($arr[$j], $arr[$j-1]);
}
$j++;
}
}
return $arr;
}
6、快速排序算法
function quick_sort(&$arr, $p, $r){
if($p < $r){
$q = partition($arr, $p, $r);
quick_sort($arr, $p, $q-1);
quick_sort($arr, $q+1, $r);
}
}
function partition(&$arr, $p, $r){
$i = rand($p, $r); //实现随机化快排
exchange($arr[$i], $arr[$r]);
$n=$p-1;
for($m = $p; $m < $r; $m++){
if($arr[$m] < $arr[$r]){
++$n;
exchange($arr[$m], $arr[$n]);
}
}
exchange($arr[$n+1], $arr[$r]);
return $n+1; //n位上的元素,一经排序,则已固定
}
7、归并排序算法【注意:数组按值传输】
function merge_sort(&$A, $p, $r){
if($p < $r){
$q = floor(($p + $r)/2);
merge_sort($A, $p, $q);
merge_sort($A, $q+1, $r);
merge($A, $p, $q, $r);
}
}
//第一种
function merge(&$A, $p, $q, $r){ //哨兵牌法
$n1 = $q - $p + 1;
$n2 = $r - $q;
for($i = 0; $i < $n1; $i++){
$L[$i] = $A[$p+$i];
}
for($j = 0; $j < $n2; $j++){
$R[$j] = $A[$q+$j+1];
}
//防止越界(哨兵)
$L[$n1] = $R[$n2] = PHP_INT_MAX;
$i = $j = 0;
for($k = $p; $k <= $r; $k++){
if($L[$i] <= $R[$j]){
$A[$k] = $L[$i];
$i++;
}else{
$A[$k] = $R[$j];
$j++;
}
}
}
//第二种
function merge(&$A, $p, $q, $r){
$n1 = $q - $p + 1;
$n2 = $r - $q;
for($i = 0; $i < $n1; $i++){
$L[$i] = $A[$p+$i];
}
for($j = 0; $j < $n2; $j++){
$R[$j] = $A[$q+$j+1];
}
$i = $j = 0;
$k = $p;
while($i<$n1 && $j<$n2){
if($L[$i] <= $R[$j]){
$A[$k++] = $L[$i++];
}else{
$A[$k++] = $R[$j++];
}
}
for(; $i<$n1; $i++){
$A[$k++] = $L[$i];
}
for(; $j<$n2; $j++){
$A[$k++] = $R[$j];
}
}
8、基数排序算法【暂缺】
算法-PHP实现八大算法的更多相关文章
- 算法:Astar寻路算法改进,双向A*寻路算法
早前写了一篇关于A*算法的文章:<算法:Astar寻路算法改进> 最近在写个js的UI框架,顺便实现了一个js版本的A*算法,与之前不同的是,该A*算法是个双向A*. 双向A*有什么好处呢 ...
- Atitit.软件中见算法 程序设计五大种类算法
Atitit.软件中见算法 程序设计五大种类算法 1. 算法的定义1 2. 算法的复杂度1 2.1. Algo cate2 3. 分治法2 4. 动态规划法2 5. 贪心算法3 6. 回溯法3 7. ...
- JVM内存管理------GC算法精解(复制算法与标记/整理算法)
本次LZ和各位分享GC最后两种算法,复制算法以及标记/整理算法.上一章在讲解标记/清除算法时已经提到过,这两种算法都是在此基础上演化而来的,究竟这两种算法优化了之前标记/清除算法的哪些问题呢? 复制算 ...
- 缓存算法(页面置换算法)-FIFO、LFU、LRU
在前一篇文章中通过leetcode的一道题目了解了LRU算法的具体设计思路,下面继续来探讨一下另外两种常见的Cache算法:FIFO.LFU 1.FIFO算法 FIFO(First in First ...
- opencv3中的机器学习算法之:EM算法
不同于其它的机器学习模型,EM算法是一种非监督的学习算法,它的输入数据事先不需要进行标注.相反,该算法从给定的样本集中,能计算出高斯混和参数的最大似然估计.也能得到每个样本对应的标注值,类似于kmea ...
- Floyd-Warshall算法,简称Floyd算法
Floyd-Warshall算法,简称Floyd算法,用于求解任意两点间的最短距离,时间复杂度为O(n^3). 使用条件&范围通常可以在任何图中使用,包括有向图.带负权边的图. Floyd-W ...
- 8皇后以及N皇后算法探究,回溯算法的JAVA实现,非递归,循环控制及其优化
上两篇博客 8皇后以及N皇后算法探究,回溯算法的JAVA实现,递归方案 8皇后以及N皇后算法探究,回溯算法的JAVA实现,非递归,数据结构“栈”实现 研究了递归方法实现回溯,解决N皇后问题,下面我们来 ...
- 最短路径算法之二——Dijkstra算法
Dijkstra算法 Dijkstra算法主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止. 注意该算法要求图中不存在负权边. 首先我们来定义一个二维数组Edge[MAXN][MAXN]来存储 ...
- 页面置换算法(最佳置换算法、FIFO置换算法、LRU置换算法、LFU置换算法)
页面置换产生的原因是:分页请求式存储管理(它是实现虚拟存储管理的方法之一,其中一个特性是多次性-->多次将页面换入或换出内存) 效果最好的页面置换算法:最佳置换算法 比较常用的页面置换算法有:F ...
随机推荐
- June 22nd 2017 Week 25th Thursday
Happiness is when the desolated soul meets love. 幸福是孤寂的灵魂遭遇爱的邂逅. When living alone for a long period ...
- vim c++插件clang_complete
地址 http://www.vim.org/scripts/script.php?script_id=3302 以后应该会用到的,先记下:需要安装clang编译器.
- What is Systems Architecture ?
What is Systems Architecture ? Systems Architecture is a generic discipline to handle objects (exi ...
- 汇编试验十五:安装新的int 9中断例程
安装新的int 9中断例程(按'A'键后显示满屏幕的'A') int 9 是外中断,同样,程序编写还是和其他中断例程类似,安装(复制),调用: 不同点是在于,他要从端口读取数据60h, Source ...
- springmvc(2)处理器设配器和映射器
非注解的处理器 映射器 和 适配器 一.处理器映射器 1.BeanNameUrlHandlerMapping <bean class="org.springframework.web ...
- XXE攻防——XML外部实体注入
XXE攻防——XML外部实体注入 转自腾讯安全应急响应中心 一.XML基础知识 XML用于标记电子文件使其具有结构性的标记语言,可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语言进行定义的 ...
- resnet densenet
1.resnet的skip connection是通过eltwise相加的 2.resnet做detection的时候是在conv4_x的最后一层(也就是stage4的最后一层),因为这个地方stri ...
- Python:文件的读取、创建、追加、删除、清空
一.用Python创建一个新文件,内容是从0到9的整数, 每个数字占一行:#python>>>f=open('f.txt','w') # r只读,w可写,a追加>> ...
- JS异步编程 (2) - Promise、Generator、async/await
JS异步编程 (2) - Promise.Generator.async/await 上篇文章我们讲了下JS异步编程的相关知识,比如什么是异步,为什么要使用异步编程以及在浏览器中JS如何实现异步的.最 ...
- Notes 20180306 : 变量与常量
1.1 变量与常量 我们在开发中会经常听到常量和变量,那么常量和变量指的又是什么呢?顾名思义,在程序执行过程中,其值不能被改变的量称为常量,其值能被改变的量称为变量.变量与常量的命名都必须使用合法的标 ...