Java排序演算法速度比較(轉載)
public class Sort {
public void swap(int a[], int i, int j) {
int tmp = a[i];
a[i] = a[j];
a[j] = tmp;
}
public int partition(int a[], int low, int high) {
int pivot, p_pos, i;
p_pos = low;
pivot = a[p_pos];
for (i = low + 1; i <= high; i++) {
if (a[i] > pivot) {
p_pos++;
swap(a, p_pos, i);
}
}
swap(a, low, p_pos);
return p_pos;
}
public void quicksort(int a[], int low, int high) {
int pivot;
if (low < high) {
pivot = partition(a, low, high);
quicksort(a, low, pivot - 1);
quicksort(a, pivot + 1, high);
}
}
public static void main(String args[]) {
int vec[] = new int[] { 37, 47, 23, -5, 19, 56 };
int temp;
//選擇排序法(Selection Sort)
long begin = System.currentTimeMillis();
for (int k = 0; k < 1000000; k++) {
for (int i = 0; i < vec.length; i++) {
for (int j = i; j < vec.length; j++) {
if (vec[j] > vec[i]) {
temp = vec[i];
vec[i] = vec[j];
vec[j] = temp;
}
}
}
}
long end = System.currentTimeMillis();
System.out.println("選擇法用時為:" + (end - begin));
//列印排序好的結果
for (int i = 0; i < vec.length; i++) {
System.out.println(vec[i]);
}
// 氣泡排序法(Bubble Sort)
begin = System.currentTimeMillis();
for (int k = 0; k < 1000000; k++) {
for (int i = 0; i < vec.length; i++) {
for (int j = i; j < vec.length - 1; j++) {
if (vec[j + 1] > vec[j]) {
temp = vec[j + 1];
vec[j + 1] = vec[j];
vec[j] = temp;
}
}
}
}
end = System.currentTimeMillis();
System.out.println("冒泡法用時為:" + (end - begin));
//列印排序好的結果
for (int i = 0; i < vec.length; i++) {
System.out.println(vec[i]);
}
//插入排序法(Insertion Sort)
begin = System.currentTimeMillis();
for (int k = 0; k < 1000000; k++) {
for (int i = 1; i < vec.length; i++) {
int j = i;
while (vec[j - 1] < vec[i]) {
vec[j] = vec[j - 1];
j--;
if (j <= 0) {
break;
}
}
vec[j] = vec[i];
}
}
end = System.currentTimeMillis();
System.out.println("插入法用時為:" + (end - begin));
//列印排序好的結果
for (int i = 0; i < vec.length; i++) {
System.out.println(vec[i]);
}
//快速排序法(Quick Sort)
Sort s = new Sort();
begin = System.currentTimeMillis();
for (int k = 0; k < 1000000; k++) {
s.quicksort(vec, 0, 5);
}
end = System.currentTimeMillis();
System.out.println("快速法用時為:" + (end - begin));
//列印排序好的結果
for (int i = 0; i < vec.length; i++) {
System.out.println(vec[i]);
}
}
}以下是執行結果:選擇法用時為:23456
47
37
23
19
-5冒泡法用時為:17256
47
37
23
19
-5插入法用時為:7856
47
37
23
19
-5快速法用時為:29756
47
37
23
19
-5
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10455649/viewspace-968941/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 排序演算法效能比較排序演算法
- 常用的比較排序演算法總結排序演算法
- 三種高階比較排序演算法排序演算法
- 艾偉_轉載:從ASP.NET的PHP執行速度比較談起ASP.NETPHP
- 堆排序和快速排序效能比較排序
- 定製排序和比較器排序排序
- 11.經典O(n²)比較型排序演算法排序演算法
- 幾種排序的比較排序
- 氣泡排序、歸併排序與快速排序比較排序
- Prometheus thanos Victoriametrics比較 victoria prometheus 區別 轉載Prometheus
- Java 比較器Java
- javascript訪問不同物件的速度比較JavaScript物件
- 《演算法筆記》4. 堆與堆排序、比較器詳解演算法筆記排序
- 排序演算法對比排序演算法
- java比較日期大小Java
- Java和JavaSciprt比較Java
- java--BEAN比較JavaBean
- 【JAVA演算法】排序演算法 -- 快速排序Java演算法排序
- 利用compareTo方法進行字串比較排序字串排序
- java排序方式對比Java排序
- 排序演算法-Java排序演算法Java
- Java的BigDecimal比較大小JavaDecimal
- 排序演算法-Java實現快速排序演算法排序演算法Java
- 【資料結構與演算法】非比較排序(計數排序、桶排序、基數排序)資料結構演算法排序
- Java排序演算法之氣泡排序Java排序演算法
- java檔案複製方式在100MB檔案條件下速度的比較Java
- Java Go python 執行速度對比JavaGoPython
- [轉載] 一篇比較好的 Cypress 特點介紹文章
- Java中List集合效能比較Java
- Java 字串比較、拼接問題Java字串
- Java 中 Comparable 和 Comparator 比較Java
- Java字串建立方式比較Java字串
- 初練演算法,比較演算法之美演算法
- 演算法:比較含退格的字串演算法字串
- 有的代理伺服器速度比較慢是為什麼?伺服器
- 排序演算法:Java實現希爾排序排序演算法Java
- Java 17的計算速度比Java 8慢? - marianJava
- 轉載:十大經典排序的演算法部落格排序演算法
- 排序演算法Java實現排序演算法Java