搜尋
首頁php教程PHP开发冒泡排序優化版,效能近乎翻倍
冒泡排序優化版,效能近乎翻倍Dec 19, 2016 pm 01:42 PM
冒泡排序

原始的冒泡排序相對而言是非常耗時的,即使一個數組經過幾輪交換已經變的有序了,例如[2,1,3,4,5,6,7]這個數組,經過第一輪,已經變成有序的了,但頑固的冒泡還是要繼續進行沒有營養的兩兩比較,從而犧牲了時間。

如果用一個flag來判斷一下,當前數組是否已經有序,如果有序就退出循環,這樣可以明顯的提高冒泡排序的表現~

由於冒泡排序的時間複雜度為O(n* n)所以當資料越多的時候,越慢,非常不適合大數據的排序,所以我們測試的時候也是用的長度為800的隨機數組。

程式碼如下:

package go.derek;
import java.util.*;
public class Sort {
 //冒泡排序
 public void bubbleSort(int[] arr//冒泡排序
 public void bubbleSort(int[] arrarr)(); i   for(int j=arr.length-1;j>i;j--){
    if(arr[j]    int tmp=arr[j];
     arr[j]=arr[j-1];
     arr[j-1]=tmp;
    }
   }
  }
    }
   }
  }
    }
   }
  }
 bubbleSort_plus(int[] arr){
  boolean flag=true;
  for(int i=0;i   flag=false;
   . j>i;j--){
    if(arr[j]     flag=true;
     int tmp=arr[j];   ];
     arr[j-1]=tmp;
    }
   }
  }
 }
 public static void main(String[] args){
){
Sort public static void main(String[] args){
. 800];
  for(int i=0;i   arr1[i]=new Random().nextInt(800)+1;
  }  int[] arrarr2=new int[80000 ];
  for(int i=0;i   arr2[i]=new Random().nextInt(800)+1;
  }
  long n=System.currentrent+1;
  }
  long n=System.currentrent s.bubbleSort_plus(arr1);
  long m=System.currentTimeMillis();
  System.out.println("冒泡排序耗時:"+(m-n)+"ms");
  long a=System.currentTimeMillis(  long a=System.currentTimeMillis( );
  s.bubbleSort_plus(arr2);

  long b=System.currentTimeMillis();

  System.out.println("優化之後耗時:"+(b-a)+"ms");

多次運行之後發現了效果最明顯的一次結果:

冒泡排序耗時:12ms

優化之後耗時:4ms

可以這個flag的重要性哦~

🎜更多冒泡排序優化版,性能近乎翻倍相關文章請關注PHP中文網! 🎜
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
如何实现C#中的冒泡排序算法如何实现C#中的冒泡排序算法Sep 19, 2023 am 11:10 AM

如何实现C#中的冒泡排序算法冒泡排序是一种简单但有效的排序算法,它通过多次比较相邻的元素并交换位置来排列一个数组。在本文中,我们将介绍如何使用C#语言实现冒泡排序算法,并提供具体的代码示例。首先,让我们了解一下冒泡排序的基本原理。算法从数组的第一个元素开始,与下一个元素进行比较。如果当前元素比下一个元素大,则交换它们的位置;如果当前元素比下一个元素小,则保持

PHP 数组自定义排序算法的编写指南PHP 数组自定义排序算法的编写指南Apr 27, 2024 pm 06:12 PM

如何编写自定义PHP数组排序算法?冒泡排序:通过比较和交换相邻元素来排序数组。选择排序:每次选择最小或最大元素并将其与当前位置交换。插入排序:逐个插入元素到有序部分。

C++ 函数性能优化中的算法选择与优化技巧C++ 函数性能优化中的算法选择与优化技巧Apr 23, 2024 pm 06:18 PM

C++函数性能优化算法选择:选择高效算法(如快速排序、二分查找)。优化技巧:内联小型函数、优化缓存、避免深拷贝、循环展开。实战案例:查找数组最大元素位置时,优化后采用二分查找和循环展开,大幅提升性能。

各种 PHP 数组排序算法的复杂度分析各种 PHP 数组排序算法的复杂度分析Apr 27, 2024 am 09:03 AM

PHP数组排序算法复杂度:冒泡排序:O(n^2)快速排序:O(nlogn)(平均)归并排序:O(nlogn)

冒泡事件的含义是什么冒泡事件的含义是什么Feb 19, 2024 am 11:53 AM

冒泡事件是指在Web开发中,当一个元素上触发了某个事件后,该事件将会向上层元素传播,直到达到文档根元素。这种传播方式就像气泡从底部逐渐冒上来一样,因此被称为冒泡事件。在实际开发中,了解和理解冒泡事件的工作原理对于正确处理事件十分重要。下面将通过具体的代码示例来详细介绍冒泡事件的概念和使用方法。首先,我们创建一个简单的HTML页面,其中包含一个父级元素和三个子

分析 Go 语言中的时间复杂度和空间复杂度分析 Go 语言中的时间复杂度和空间复杂度Mar 27, 2024 am 09:24 AM

Go语言是一种越来越流行的编程语言,它被设计成易于编写、易于阅读和易于维护的语言,同时也支持高级编程概念。时间复杂度和空间复杂度是算法和数据结构分析中重要的概念,它们衡量着一个程序的执行效率和占用内存大小。在本文中,我们将重点分析Go语言中的时间复杂度和空间复杂度。时间复杂度时间复杂度是指算法执行时间与问题规模之间的关系。通常用大O表示法来表示时间

Python、Java和C++:哪个编程语言更值得学习?Python、Java和C++:哪个编程语言更值得学习?Mar 29, 2024 pm 02:06 PM

Python、Java和C++:哪个编程语言更值得学习?作为计算机科学领域中最常见的编程语言之一,Python、Java和C++各自具有独特的特点和优势。选择学习哪种编程语言往往取决于个人的兴趣、职业需求和项目要求。在选择编程语言时,比较它们的特性和适用场景是非常重要的。接下来将分别探讨这三种编程语言的特点,并给出相应的代码示例。Python:Python是

冒泡排序是什么冒泡排序是什么Aug 29, 2023 pm 02:31 PM

冒泡排序是一种简单但效率较低的排序算法,它的原理是通过相邻元素之间的比较和交换,将最大的元素逐渐“冒泡”到数组的末尾,冒泡排序的时间复杂度为O(n^2),其中n是待排序数组的长度。详细介绍:从数组的第一个元素开始,依次比较相邻的两个元素,如果前一个元素大于后一个元素,则交换它们的位置,一轮比较下来,最大的元素就会“冒泡”到数组的末尾,再从数组的第一个元素开始,重复上操作等等。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境