首頁 後端開發 php教程 簡單排序演算法 java排序演算法 排序演算法總結 堆排序算

簡單排序演算法 java排序演算法 排序演算法總結 堆排序算

Jul 29, 2016 am 08:52 AM
排序演算法 簡單

$arr = array(
    12,
    45,
    89,
     76,
    22,
    11,
    28,
    112,
    20,
   ,
    23,
    65,
    65,
    765,
    6, 33,
    553,
    45,
    423,
    64,
     ;
/**
 * 冒泡排序演算法,時間複雜度n2/2次
 * 冒泡排序的基本概念是:依序比較相鄰的兩個數,將小數放在前面,大數放在後面。即在第一趟:先比較第1個和第2個數,將小數放前,大數放後。
 * 然後比較第2個數和第3個數,將小數放前,大數放後,如此繼續,直至比較最後兩個數,將小數放前,大數放後。至此第一趟結束,將最大的數放到了最 後。
 * 在第二趟:仍從第一對數開始比較(因為可能由於第2個數和第3個數的交換,使得第1個數不再小於第2個數),將小數放前,大數放後,一直比較到倒數第二個數
 * (倒數第一的位置上已經是最大的),第二趟結束,在倒數第二個數的位置上得到一個新的最大數(其實在整個數列中是第二大的數)。如此下去,重複以上過 程,
 * 直至最終完成排序。
 */
function maopao_sort($arr)
{
    $count = count($arr);
    $tmp;          for ($j = 0; $j         $j + 1]) {
                $tmp = $arr[$j];
                   $arr[$j + 1] = $tmp;
            }
            $m ++;
        }
    }
    print_r($arr)); sort($arr)
{
    $count = count($arr );
    $tmp;
    $m = 0; // 用於計算執行多少次
    for ($i = 0; $i ;   for ($j = $i + 1; $j             if ($arr[$p] > $arr[$j]) {
         }
$m ++;
        }
        if ($p != $i) {
         = $arr[$i];
            $arr[$i ] = $tmp;
        }
    }
    print_r($arr);
    echo $m; ($arr) ;
    $tmp;
    $m = 0; // 用來計算執行多少次
    for ($i = 1; $i    
        for ($j = $i - 1; $j >= 0; $j --) {
             1] = $arr[ $j];
                $arr[$j] = $tmp;
                      }
            $m ++;
        }
/ **
 * 快速排序演算法,時間複雜度n2/2次
 * 此方法的基本想法是:
 * 1.先從數列中取出一個數字作為基準數。
 * 2.分區過程,將比這個數大的數全放到它的右邊,小於或等於它的數全放到它的左邊。
 * 3.再對左右區間重複第二步,直到各區間只有一個數。
 */
function Quick_sort($arr)
{
    $count = count($arr);
   if ($count     $left_array = array();
    $right_array = array();
    
    ) {
            $left_array[] = $arr[$i];
        } else {
      }
        $m ++;
    }
   
    $left_array =快速排序( $left_array);
    $right_array = fast_sort($right_array);
    return array_merge($left_array, array(
   right $c (quick_sort($arr));
/ / / print_r(quickSort($arr));
function fastpaixu($arr)
{
    $count = count($arr);
   $arr[0]; // 取一個值,稍後用來比較;
    $left_arr = array();
    $right_arr = array();
    for ($i = 1; $i         if ($arr[$i]            [] = $arr[$i];
        }
    }
    $left_arr = Quickpaixu($left_arr); // 遞歸;
    $right_arr = Quickpaixu($right_arr);
    return array_merge($left_arr, array(
     // 將左中右的數值合併成一份;
} // 以下是測試
  // print_r(quickpaixu($arr));
?>
以上就介紹了簡單的排序演算法,包含排序演算法、簡單方面的內容,希望對PHP教學有興趣的朋友有幫助。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24
最簡單的硬碟序號查詢方式 最簡單的硬碟序號查詢方式 Feb 26, 2024 pm 02:24 PM

硬碟序號是硬碟的一個重要標識,通常用於唯一標識硬碟以及進行硬體識別。在某些情況下,我們可能需要查詢硬碟序號,例如在安裝作業系統、尋找正確裝置驅動程式或進行硬碟維修等情況下。本文將介紹一些簡單的方法,幫助大家查詢硬碟序號。方法一:使用Windows命令提示字元開啟命令提示字元。在Windows系統中,按下Win+R鍵,輸入"cmd"並按下回車鍵即可開啟命

快手雙邊市場的複雜實驗設計問題 快手雙邊市場的複雜實驗設計問題 Apr 15, 2023 pm 07:40 PM

一、問題背景1、雙邊市場實驗介紹雙邊市場,即平台,包含生產者與消費者兩方參與者,雙方相互促進。例如快手有影片的生產者,影片的消費者,兩種身分可能有一定程度重疊。雙邊實驗是在生產者和消費者端組合分組的實驗方式。雙邊實驗有以下優點:(1)可以同時偵測新策略對兩方面的影響,例如產品DAU和上傳作品人數變化。雙邊平台往往有跨邊網路效應,讀者越多,作者越活躍,作者越活躍,讀者也會跟著增加。 (2)可以檢測效果溢出和轉移。 (3)幫助我們更好得理解作用的機制,AB實驗本身不能告訴我們原因和結果之間的關係,只

如何透過PHP編寫一個簡單的線上預約系統 如何透過PHP編寫一個簡單的線上預約系統 Sep 26, 2023 pm 09:55 PM

如何透過PHP編寫一個簡單的線上預約系統隨著網路的普及和使用者對便利性的追求,線上預約系統越來越受到歡迎。無論是餐廳、醫院、美容院或其他服務業,都可以透過簡單的線上預約系統來提高效率並為使用者提供更好的服務體驗。本文將介紹如何使用PHP編寫一個簡單的線上預約系統,並提供具體的程式碼範例。建立資料庫和表格首先,我們需要建立一個資料庫來儲存預約資訊。在MyS

MySQL表設計指南:建立一個簡單的員工考勤表 MySQL表設計指南:建立一個簡單的員工考勤表 Jul 01, 2023 pm 01:54 PM

MySQL表設計指南:建立一個簡單的員工考勤表在企業管理中,員工的考勤管理是至關重要的任務。為了準確記錄和統計員工的考勤情況,我們可以利用MySQL資料庫來建立一個簡單的員工考勤表。本篇文章將指導您如何設計和建立這個表,並提供相應的程式碼範例。首先,我們需要確定員工考勤表所需的欄位。一般來說,員工考勤表至少需要包含以下欄位:員工ID、日期、上班時間、下班時

如何使用Java來寫一個簡單的學生成績報表產生器? 如何使用Java來寫一個簡單的學生成績報表產生器? Nov 03, 2023 pm 02:57 PM

如何使用Java來寫一個簡單的學生成績報表產生器?學生成績報表產生器是可以幫助老師或教育者快速產生學生成績報告的工具。本文將介紹如何使用Java來撰寫簡單的學生成績報表產生器。首先,我們要定義學生對象和學生成績對象。學生對象包含學生的姓名、學號等基本訊息,而學生成績對象則包含學生的科目成績和平均成績等資訊。以下是一個簡單的學生物件的定義:public

如何透過C++寫一個簡單的掃雷遊戲? 如何透過C++寫一個簡單的掃雷遊戲? Nov 02, 2023 am 11:24 AM

如何透過C++寫一個簡單的掃雷遊戲?掃雷遊戲是一款經典的益智類遊戲,它要求玩家根據已知的雷區佈局,在沒有踩到地雷的情況下,揭示所有的方塊。在這篇文章中,我們將介紹如何使用C++來寫一個簡單的掃雷遊戲。首先,我們需要定義一個二維陣列來表示掃雷遊戲的地圖。數組中的每個元素可以是一個結構體,用於儲存方塊的狀態,例如是否揭示、是否有雷等資訊。另外,我們還需要定義

如何使用PHP開發簡單的檔案管理功能 如何使用PHP開發簡單的檔案管理功能 Sep 20, 2023 pm 01:09 PM

如何使用PHP開發簡單的文件管理功能簡介:文件管理功能在許多Web應用中都是不可或缺的一部分。它允許用戶上傳、下載、刪除和展示文件,為用戶提供了便捷的文件管理方式。本文將介紹如何使用PHP開發一個簡單的檔案管理功能,並提供具體的程式碼範例。一、創建專案首先,我們需要建立一個基本的PHP專案。在專案目錄下建立以下檔案:index.php:主頁面,用於顯示上傳表

如何透過C++寫一個簡單的音樂推薦系統? 如何透過C++寫一個簡單的音樂推薦系統? Nov 03, 2023 pm 06:45 PM

如何透過C++寫一個簡單的音樂推薦系統?引言:音樂推薦系統是現代資訊科技的研究熱點,它可以根據使用者的音樂偏好和行為習慣,向使用者推薦符合其口味的歌曲。本文將介紹如何使用C++來寫一個簡單的音樂推薦系統。一、收集用戶資料首先,我們需要收集用戶的音樂偏好資料。可以透過線上調查、問卷調查等方式來獲得使用者對不同類型音樂的喜好程度。將資料保存在一個文字檔案或資料庫

See all articles