ホームページ バックエンド開発 PHPチュートリアル PHP はさまざまなソートを尊重します

PHP はさまざまなソートを尊重します

Jun 13, 2016 pm 01:16 PM
amp list temp

PHP はさまざまなソートを実装します

<?php
/**
 * 各种排序
 * @author zhaojaingwei
 * @since 2011/11/21 16:14
 *
 */

$list = array(3,5,1,2,10,8,15,19,20);

//快排
function fast(&$list, $low, $high){
    if($high - $low > 5){
        while($low < $high){
            $key = excute($list, $low, $high);
            fast($list, $low, $key - 1);
            //fast($list, $key + 1, $high);//普通递归实现
            $low = $key + 1;//尾递归实现
        }
    }else{
        insert($list);
    }
}

//快排执行一次排序
function excute(&$list, $low, $high){
    swap($list, $low, ($low + $high)/2);
    $temp = $list[$low];
    while($low < $high){
        while($low < $high && $list[$high] > $temp){
            $high --;
        }

        $list[$low] = $list[$high];

        while($low < $high && $list[$low] < $temp){
            $low ++;
        }
        
        $list[$high] = $list[$low];
    }

    $list[$low] = $temp;

    return $low;
}

//堆排序
function heap(&$list){
    buildHeap($list);
    for($i = count($list) - 1; $i > 0; $i --){
        swap($list, $i, 0);
        heapfy($list, 0, $i - 1); 
    }
}

//创建堆
function buildHeap(&$list){
    for($i = (count($list) - 2)/2; $i >= 0; $i --){
         heapfy($list, $i, count($list) - 1);  
    }
}

//维护堆
function heapfy(&$list, $low, $high){
    $temp = $list[$low];

    for($i = ($low * 2 + 1); $i <= $high; $i = ($i * 2 + 1)){
        if($i < $high && $list[$i] < $list[$i + 1]){
            $i ++;   
        }

        if($temp < $list[$i]){
            swap($list, $i, $low);
            $low = $i;
        }else{
            break;
        }

    }

    $list[$low] = $temp;
}

//希尔排序
function shell(&$list){
    $a = 0;
    $code = count($list)/3 + 1;
    while($code >= 1){
        for($i = $code; $i < count($list); $i ++){
            $a ++;
            if($list[$i] < $list[$i - $code]){
                $temp = $list[$i];
                $list[$i] = $list[$i - $code];
                $j = $i - 2*$code;
                
                for(; $j >= 0 && $list[$j] > $temp; $j -= $code){
                    $list[$j + $code] = $list[$j];
                    $a ++; 
                }
                $list[$j + $code] = $temp;
            }
        }

        $code = $code/3;
    }

    echo $a;
}

//直接插入排序
function insert(&$list){
    $a = 0;
    for($i = 1; $i < count($list); $i ++){
        $a ++;
        if($list[$i] < $list[$i - 1]){
            $temp = $list[$i];
            $list[$i] = $list[$i - 1];
            
            $j = $i - 2; 
            for(; $list[$j] > $temp; $j --){
                $a ++;
                $list[$j + 1] = $list[$j]; 
            }
            
            $list[$j + 1] = $temp;
        }
    }

    echo $a;
}

//简单选择排序
function select(&$list){
    $a = 0;
    for($i = 0; $i < count($list); $i ++){
        $min = $i;
        $a ++;
        for($j = $i + 1; $j < count($list); $j ++){
            $a ++;
            if($list[$j] < $list[$min]){
                $min = $j;
            }
        }
    
        if($min != $i)
            swap($list, $i, $min);
    }
    echo $a;
}

//冒泡排序
function bubble(&$list){
    $swap = TRUE;
    $a = 0;
    for($i = 0; $i < count($list) && $swap; $i ++){
        $swap = FALSE;
        $a ++;
        for($j = count($list) - 2; $j >= $i; $j --){
            $a ++;
            if($list[$j] > $list[$j + 1]){
                $swap = TRUE;
                swap($list, $j, $j + 1);
            }
        }
    }
    echo $a;
}

//移动或交换函数
function swap(&$list, $i, $j){
    $temp = $list[$i];
    $list[$i] = $list[$j];
    $list[$j] = $temp;
}

?>
ログイン後にコピー
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Win7の一時ファイルの場所を変更する方法を教えます Win7の一時ファイルの場所を変更する方法を教えます Jan 04, 2024 pm 11:25 PM

temp フォルダは一時ファイルの保存場所です。システムは一時ファイルをこのフォルダに保存します。一時ファイルが多すぎる場合、特に一時フォルダがシステム ディスク上にある場合は、システムの動作速度に影響を与える可能性があります。テンポラリの場所を変更することで問題を解決できるので、以下を見てみましょう。 win7temp の場所を変更するチュートリアル 1. まず、「コンピューター」を右クリックし、「プロパティ」を開きます。 2. 左側の「システムの詳細設定」をクリックします。 3. 下の「環境変数」をクリックします。 4. 「temp」を選択し、「」をクリックします。 「編集」 5. そして変更 「変数値」を変更が必要なパスに変更するだけです。

PHPでRedisリスト操作を実装する方法 PHPでRedisリスト操作を実装する方法 May 26, 2023 am 11:51 AM

リスト操作 //リストの先頭から値を挿入します。 $ret=$redis->lPush('city','guangzhou');//リストの末尾から値を挿入します。 $ret=$redis->rPush('city','guangzhou');//リストの指定範囲内の要素を取得します。 0 はリストの最初の要素を表し、-1 は最後の要素を表し、-2 は最後から 2 番目の要素を表します。 $ret=$redis->l

Windows 11/10でプロセッサーのサーマルトリップエラーを修正する方法[修正] Windows 11/10でプロセッサーのサーマルトリップエラーを修正する方法[修正] Apr 17, 2023 am 08:13 AM

ラップトップやデスクトップなどのデバイスのほとんどは、若いゲーマーやプログラマーによって長年にわたって頻繁に使用されてきました。アプリケーションの過負荷により、システムがハングすることがあります。これにより、ユーザーはシステムを強制的にシャットダウンする必要があります。これは主に、重いゲームをインストールしてプレイするプレイヤーに発生します。強制シャットダウン後にシステムが起動しようとすると、以下に示すような黒い画面でエラーがスローされます。 以下は、この起動中に検出された警告です。これらは、イベント ログ ページの設定で表示できます。警告: プロセッサーの温度トリップ。何かキーを押すと続行します。 ..これらのタイプの警告メッセージは、デスクトップまたはラップトップのプロセッサ温度がしきい値温度を超えると常にスローされます。 Windows システムでこの問題が発生する理由を以下に示します。重いアプリケーションがたくさんあります

コンピューターにおける温度とは何を意味しますか? コンピューターにおける温度とは何を意味しますか? Sep 29, 2021 pm 04:39 PM

コンピュータでは、temp は「一時フォルダ」を意味し、多くの一時ファイルが格納されていますが、その機能は、事故による損失を防ぐために、アプリケーション内でユーザーの作業結果を一時的に保存することです。一時ファイルを削除するとハードディスクのストレージ領域を解放できますが、削除後に初めてアプリケーションを開くときの速度が遅くなります。

内部エラー: 一時ディレクトリを作成できません [解決済み] 内部エラー: 一時ディレクトリを作成できません [解決済み] Apr 17, 2023 pm 03:04 PM

Windows システムでは、ユーザーは実行可能ファイル/セットアップ ファイルを使用してさまざまな種類のアプリケーションをシステムにインストールできます。最近、多くの Windows ユーザーが、実行可能ファイルを使用してアプリケーションをインストールしようとすると、システム上で INTERNALERROR:cannotCreateTemporaryDirectory というエラーが表示されると苦情を言い始めています。この問題はこれに限定されず、Windows システムにインストールされている既存のアプリケーションをユーザーが起動することもできなくなります。考えられる理由のいくつかを以下に示します。管理者権限を付与せずに実行可能ファイルを実行してインストールします。 TMP 変数に無効なパス、または異なるパスが指定されました。破損したシステム

tempファイルとは何ですか? tempファイルとは何ですか? Jan 05, 2021 am 10:43 AM

temp は一時フォルダーです。パス「C:\Documents and Settings\Administrator\Local Settings\」には、お気に入り、Web ページの閲覧、ファイル編集用の一時ファイルなど、多くの一時ファイルがここに配置されます。

JavaでJSONArrayをリストに変換する方法 JavaでJSONArrayをリストに変換する方法 May 04, 2023 pm 05:25 PM

1: JSONArray を List にJSONArray 文字列を List に//JSONArray を初期化するJSONArrayarray=newJSONArray();array.add(0,"a");array.add(1,"b");array.add(2,"c") ; Listlist=JSONObject.parseArray(array.toJSONString(),String.class);System.out.println(list.to

AMPとは何のコインですか? AMPとは何のコインですか? Feb 24, 2024 pm 09:16 PM

AMPコインとは何ですか? AMP トークンは、Synereo プラットフォームの主要取引通貨として 2015 年に Synereo チームによって作成されました。 AMP トークンは、複数の機能と用途を通じてユーザーに優れたデジタル経済体験を提供することを目的としています。 AMP トークンの目的 AMP トークンには、Synereo プラットフォームで複数の役割と機能があります。まず、プラットフォームの暗号通貨報酬システムの一部として、ユーザーはコンテンツを共有および宣伝することで AMP 報酬を獲得できます。これは、ユーザーがプラットフォームのアクティビティにより積極的に参加することを促すメカニズムです。 AMP トークンは、Synereo プラットフォームでコンテンツを宣伝および配布するために使用することもできます。ユーザーは、AMP トークンを使用して、より多くの視聴者に視聴して共有してもらうことで、プラットフォーム上でのコンテンツの可視性を高めることができます。

See all articles