heapsort(PHP)
练习堆排序的一个程序<?
//堆排序应用
class heapsort
{
var $a;
function setarray($a)//取得数组
{
$this->a=$a;
}
function runvalue($b,$c)//$a 代表数组,$b代表排序堆,$c代表结束点,
{
while($b<$c)
{
$h1=2*$b;
$h2=(2*$b+1);
if($h1>$c)
break;
elseif($h1==$c)
{
if($this->a[$b]>$this->a[$h1])
{
$t=$this->a[$b];
$this->a[$b]=$this->a[$h1];
$this->a[$h1]=$t;
$la=1;
}
else
$la=1;
}
elseif(($this->a[$b]>$this->a[$h1])||($this->a[$b]>$this->a[$h2]))
{
if($this->a[$h1]>=$this->a[$h2])
{
$t=$this->a[$h2];
$this->a[$h2]=$this->a[$b];
$this->a[$b]=$t;
$b=$h2;
}
else
{
$t=$this->a[$h1];
$this->a[$h1]=$this->a[$b];
$this->a[$b]=$t;
$b=$h1;
}
}
else
$la=1;
if($la==1)
break;
}
}
function getarray()
{
$all=count($this->a);
$b=Floor(($all-1)/2);
for($i=$b;$i>=1;$i--)//先将数组建立成堆
{
$this->runvalue($i,($all-1));
}
for($i=1;$i<$all;$i++)
{
$a1=($all-$i);
if($i==1)
{
$t=$this->a[1];
$this->a[1]=$this->a[$a1];
$this->a[$a1]=$t;
}
else
{
$end=($all-$i);
$this->runvalue(1,$end);
$t=$this->a[1];
$this->a[1]=$this->a[$end];
$this->a[$end]=$t;
}
}
return $this->a;
}
}
//////
class sortarr
{
var $a;
function setarray($a)//取得数组
{
$this->a=$a;
}
function runvalue($i)
{
$max=$this->a[$i];
$id=$i;
for($j=($i+1);$j<count($this->a);$j++)
{
if($this->a[$j]>$max)
{
$max=$this->a[$j];
$id=$j;
}
}
if($id!=$i)
{
$t=$this->a[$id];
$this->a[$id]=$this->a[$i];
$this->a[$i]=$t;
}
}
function getarray()
{
for($i=1;$i<(count($this->a)-1);$i++)
$this->runvalue($i);
return $this->a;
}
}
//////
$s=microtime();
$st=explode(@# @#,$s);
$st1=$st[0];
$st2=$st[1];
//////
$v=10000;//排序数组长度
$brr[0]=0;
for($i=1;$i<$v;$i++)
{
$brr[$i]=rand();
}
$check=2;//1 stand for heapsort 2 stand for another sort
echo@#after sort!!<br>@#;
if($check==1)
{
$arr=new heapsort;
$arr->setarray($brr);
$ok=$arr->getarray();
for($i=1;$i<$v;$i++)
{
$j=((($i+1)>($v-1))?($v-1):($i+1));
/*
if($ok[$j]<$ok[$i])
echo@#<font color=red>@#.$ok[$i].@#</font><br>@#;
else
echo$ok[$i].@#<br>@#;*/
}
}
elseif($check==2)
{
$arr=new sortarr;
$arr->setarray($brr);
$ok=$arr->getarray();
for($i=1;$i<$v;$i++)
{
$j=((($i+1)>($v-1))?($v-1):($i+1));/*
if($ok[$j]<$ok[$i])
echo@#<font color=red>@#.$ok[$i].@#</font><br>@#;
elseif($ok[$j]>$ok[$i])
echo@#<font color=green>@#.$ok[$i].@#</font><br>@#;
else
echo$ok[$i].@#<br>@#;*/
}
}
elseif($check==3)
{
sort($brr);
$ok=$brr;
for($i=1;$i<$v;$i++)
{
$j=((($i+1)>($v-1))?($v-1):($i+1));/*
if($ok[$j]<$ok[$i])
echo@#<font color=red>@#.$ok[$i].@#</font><br>@#;
elseif($ok[$j]>$ok[$i])
echo@#<font color=green>@#.$ok[$i].@#</font><br>@#;
else
echo$ok[$i].@#<br>@#;*/
}
}
else
{
echo@#参数输入错误!!<br>@#;
}
//////
$s=microtime();
$st=explode(@# @#,$s);
$sta=$st[0];
$stb=$st[1];
$ss1=$sta-$st1;
$ss2=$stb-$st2;
if($check==1)
$word=@#堆排序@#;
elseif($check==2)
$word=@#常规排序@#;
elseif($check==3)
$word=@#普通排序@#;
else
$word=@#无排序@#;
echo$word.@#对具有@#.$v.@#个元素的数组排序,消耗了@#.($ss2+$ss1).@#秒时间@#;
//////
?>
- · 一个双向加密解密法(php)
- · PHP如何调用JAVA 类库
- · 用于测试php函数的代码
- · PHP4+PWS在Windows 9x下的安装和配置
- · 用javascript+PHP随机显示图片
- · PHP4实际应用经验篇
- · POP3、SMTP邮件收发程序
- · 在PHP中显示格式化的用户输入
- · 使用PHP 5.0 轻松解析XML文档(6)
- · 使用PHP 5.0 轻松解析XML文档(4)
- · 使用PHP 5.0 轻松解析XML文档(2)
- · PHP中实现面向对象编程(下)
- · 用PHP实现WEB动态网页静态化
- · 让你的PHP引擎全速运转
- · 自动发布新闻的php代码
- · 在PHP中将图片存放ORACLE中
- · PHP应用分页显示制作详细讲解(1)
- · PHP5中使用Web服务访问J2EE应用程序(3)
- · PHP5中使用Web服务访问J2EE应用程序(1)
- · PHP开发中文件操作疑难问答
- · 用Portal来集成外部应用程序
- · php+dbfile开发小型留言本
- · 用GD图库生成横竖柱状图折线图的类
- · 用php实现真正的----连动下拉列表
- · PHP快速模板技术
- · PHP中的Java扩展
- · php注入3
- · php注入1
- · PHP中类的理解和应用[一]
- · 一个用PHP实现的UBB类!
- · php有关于正则表达式的详细说明
- · 高质量缩略图的生成函数(多种剪切模式,按高度宽度最佳缩放等)
- · Whats New in PHP 5 countstars(翻译)
- · 用php实现gb2312和unicode间的编码转换
- · php中检查email完整性
- · PHP生成静态页面详解
- · 解决PHP存取MySQL 4.1乱码问题
- · 根据来路是否为搜索引擎来决定是否跳出弹窗代码
- · 用PHP控制用户的浏览器--ob*函数的使用
- · PHP操作文件问答
- · 用PHP实现通过Web执行C/C++程序
- · 在PHP下实现持久化
- · 抛开Cookie使用SESSION-PHP中SESSION不能跨页传递问题的解决办法
- · PHP 5 连接 mysql 5 的认证协议问题
- · linux loadavg 算法

