PHP ヒープソート (heapsort) 演習_PHP チュートリアル
//ヒープソートアプリケーション
class heapsort
{
var $a;
function setarray($a)//配列を取得します
{
a=$a;
}
function runvalue ($b, $c)//$a は配列を表し、$b はソートされたヒープを表し、$c はエンドポイントを表します。 $a h2=(2*$b+1);
this->a[$b]> ; $this->a[$h1])
] ;
$this-> $this->a[$h1])||($this->a[$b]>$this- > a [$ h2])
$ h1]> = $ this-> a [$ h2])
this-> a [$ b];
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 {
$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]<$ok[$i])
echo''.$ok[$i].'< ;br>';
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].'< ;/font>
';
elseif($ok[$j]>$ok[$i])
echo''.$ok[$i].'< /font&gt;&lt; br&gt; '; ;
}
//////
$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).'秒時間';
//////
?>
http://www.bkjia.com/PHPjc/825187.html

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP へのログインは非常に簡単な作業です。使用する関数は 1 つだけです。 cronjob などのバックグラウンド プロセスのエラー、例外、ユーザー アクティビティ、ユーザーが実行したアクションをログに記録できます。 CakePHP でのデータのログ記録は簡単です。 log()関数が提供されています

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP はオープンソースの MVC フレームワークです。これにより、アプリケーションの開発、展開、保守がはるかに簡単になります。 CakePHP には、最も一般的なタスクの過負荷を軽減するためのライブラリが多数あります。
