******插入排序(一维数组)
1,从第一个元素开始,该元素可以认为已经被排序
2,取出下一个元素,在已经排序的元素序列中从后向前扫描
3,如果该元素(已排序)大于新元素,将该元素移到下一位置
4,重复步骤3,直到找到已排序的元素小于或者等于新元素的位置
5,将新元素插入到该位置中
6,重复步骤2
*/
function insert_sort($arr)
{
$len = count($arr);
for ($i=1; $i<$len; $i++)
{
$tmp = $arr[$i];
$j = $i-1;
while ($arr[$j] > $tmp && $j>=0)
{
$arr[$j+1] = $arr[$j];
$j--;
}
$arr[$j+1] = $tmp;
}
return $arr;
}
/*
******冒泡排序(一维数组)
1,比较相邻的元素。如果第一个比第二个大,就交换他们两个。
2,对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
3,针对所有的元素重复以上的步骤,除了最后一个。
4,持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。
*/
function bubble_sort($arr)
{
$len = count($arr);
for ($i=0; $i<$len; $i++)
{
for ($j=$len-1; $j>$i; $j--)
{
if ($arr[$j-1] > $arr[$j])
{
$tmp = $arr[$j-1];
$arr[$j-1] = $arr[$j];
$arr[$j] = $tmp;
}
}
}
return $arr;
}
/*
******选择排序(一维数组)
1,首先在未排序序列中找到最小元素,存放到排序序列的起始位置,
2,然后再从剩余未排序元素中继续寻找最小元素,放到排序序列末尾。
3,以此类推,直到所有元素均排序完毕。
*/
function select_sort($arr){
$count = count($arr);
for($i=0; $i<$count-1; $i++)
{
$k = $i;
for($j=$i+1; $j<$count; $j++)
{
if ($arr[$k] > $arr[$j])
{
$k = $j;
}
}
if ($k != $i)
{
$tmp = $arr[$i];
$arr[$i] = $arr[$k];
$arr[$k] = $tmp;
}
}
return $arr;
}
/*
******快速排序(一维数组)
1,先随机取一个中间值
2,把比中间值小的放到左侧,比中间值大的放到右侧,
3,然后再分别对左侧和右侧数据递归调用1,2步,合并左侧、中间值、右侧数据。
*/
function quick_sort($arr)
{
if (count($arr) <= 1)
{
return $arr;
}
$key = $arr[0];
$left_arr = array();
$right_arr = array();
for ($i=1; $i
{
if ($arr[$i] <= $key) $left_arr[] = $arr[$i];
else $right_arr[] = $arr[$i];
}
$left_arr = quick_sort($left_arr);
$right_arr = quick_sort($right_arr);
return array_merge($left_arr, $key, $right_arr);
}
$a = array(123,321,432,341345,45234,53,493);
echo "
";<br><br>print_r(select_sort($a));<br><br>print_r(bubble_sort($a));<br><br>print_r(insert_sort($a));<br><br>print_r(quick_sort($a));<br><br>echo "";

长URL(通常用关键字和跟踪参数都混乱)可以阻止访问者。 URL缩短脚本提供了解决方案,创建了简洁的链接,非常适合社交媒体和其他平台。 这些脚本对于单个网站很有价值

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

这是有关用Laravel后端构建React应用程序的系列的第二个也是最后一部分。在该系列的第一部分中,我们使用Laravel为基本的产品上市应用程序创建了一个RESTFUL API。在本教程中,我们将成为开发人员

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

2025年的PHP景观调查调查了当前的PHP发展趋势。 它探讨了框架用法,部署方法和挑战,旨在为开发人员和企业提供见解。 该调查预计现代PHP Versio的增长

在本文中,我们将在Laravel Web框架中探索通知系统。 Laravel中的通知系统使您可以通过不同渠道向用户发送通知。今天,我们将讨论您如何发送通知OV


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver Mac版
视觉化网页开发工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

SublimeText3汉化版
中文版,非常好用

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境