ヒープソートを実践するプログラム
//ヒープソートアプリケーション
class heapsort
{
var $a;
function setarray($a)//配列を取得
{
$this->a=$a ; N}
Function Runvalue ($ B, $ C) // $ a は配列を表し、$ b はソート ヒープを表し、$ c はエンドポイントを表します、
{
while ($ b & lt; $ c) {
$ h1 = 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* 2* $ b;
if($this->a[$b]>$this->a[$h1])
a[$h1]; $la=1; a[$h1])||($this->a[$b]>$this->a[$h2]))
->a[$h1]>=$this-> a [$ h2])
[$ h2] = $ this> 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 {
$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 ;
関数 setarray ($a)//取得数组
{
$this->a=$a;
}
function runvalue($i)
{
$max=$this->a[$i];
$id =$i;
for($j=($i+1);$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 はヒープソートを表します 2 は別のソートを表します
echo'after sort!!
';
if ($check==1)
{
$arr=new heapsort;
$arr->setarray($brr);
$ok=$arr->getarray();
for($i=1;$i {
$j=((( $i+1)>($v-1))?($v-1):($i+1));
/*
if($ok[$j] echo''.$ok[$i].'
';
else
echo$ok[$i].'
'; */
}
}
elseif($check==2)
{
$arr=new sortarr;
$arr->setarray($brr);
$ok=$arr->getarray();
for($i=1;$i {
$j=((($i+1)>($v-1))?($v-1):($i +1));/*
if($ok[$j] echo''.$ok[$i].'
';
elseif($ok[$j]>$ok[$i])
echo''.$ok[$i].'< ;br>';
else
echo$ok[$i].'
';*/
}
}
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''.$ok[$i].'
';
elseif($ok[$j]>$ok[$i])
echo''.$ok[$i].' ;/font>
';
else
echo$ok[$i].'
';*/
}
}
else
{
echo'パラメータ入力错误!!
}
//////
$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).'秒時間';
///////
?>