一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - java直接插入排序示例

java直接插入排序示例

2019-11-22 13:18Java教程網 JAVA教程

這篇文章主要介紹了java直接插入排序示例,插入排序的比較次數仍然是n的平方,但在一般情況下,它要比冒泡排序快一倍,比選擇排序還要快一點。它常常被用在復雜排序算法的最后階段,比如快速排序。

影響排序效率的一般從3個方面比較:數據比較的次數,數據移動的次數,內存空間占用的大小。
我們就冒泡排序、選擇排序、插入排序、快速排序做一個總的比較。一般情況下不會使用冒泡排序算法,因為它的比較次數和移動次數在幾種排序算法中都是最多的,它的唯一好處是算法簡單,易于理解,所以在數據量很小的時候它會有些應用價值。選擇排序在比較次數上和冒泡排序一樣,都是n的平方,但它把交換的次數降低到了最低,所以在數據量很小且交換數據相對于比較數據更加耗時的情況下,可以應用選擇排序。
在大多數情況下,當數據量比較小或基本上有序時,插入排序算法是最好的選擇。對于更大的數據量排序來說,快速排序通常是最好的方法。
上述排序算法在內存空間上占用很少,僅需要一個額外的變量來暫時存儲交換時的數據項。所以在內存空間占用的大小上沒有可比性。

插入排序的比較次數仍然是n的平方,但在一般情況下,它要比冒泡排序快一倍,比選擇排序還要快一點。它常常被用在復雜排序算法的最后階段,比如快速排序。

算法:經過i-1遍處理后,L[1..i-1]己排好序。第i遍處理僅將L[i]插入L[1..i-1]的適當位置,
使得L[1..i]又是排好序的序列。要達到這個目的,我們可以用順序比較的方法。
首先比較L[i]和L[i-1],如果L[i-1]<=L[i],則L[1..i]已排好序,第i遍處理就結束了;
否則交換L[i]與L[i-1]的位置,繼續比較L[i-1]和L[i-2],直到找到某一個位置j(1≤j≤i-1),
使得L[j] ≤L[j+1]時為止
優點:移動元素次數少,只需要一個輔助空間
時間復雜度n*n
當待排序記錄的數量n很小時,這是一種很好的排序方法。但是n很大時,則不適

例如:int[] values = { 5, 2, 4, 1, 3 };

排序過程:
第1次:2,5,4,1,3
第2次:2,4,5,1,3
第3次:1,2,4,5,3
第4次:1,2,3,4,5


java代碼:

復制代碼代碼如下:

public class InsertSort {
   public static void main(String[] args) {
       int[] values = { 5, 2, 4, 1, 3 };
       sort(values);
       for (int i = 0; i < values.length; ++i) {
           System.out.println(values[i]);
       }
   }
   public static void sort(int[] values) {
       int temp;
       int j = 0;
       for (int i = 1; i < values.length; i++) {
           if(values[i]<values[i-1])//此處的判斷很重要,這里體現了插入排序比冒泡排序和選擇排序快的原因。
           {
               temp = values[i];
               //數據往后移動
               for (j=i-1; j>=0 && temp<values[j]; j--)
               {
                   values[j+1] =values[j];
               }
               //將數據插入到j+1位置
               values[j+1] =temp;
               System.out.print("第" + (i + 1) + "次:");
               for (int k = 0; k < values.length; k++) {
                   System.out.print(values[k]+",");
               }
               System.out.println("");
           }
       }
   }
}

 

第二個示例

 

復制代碼代碼如下:


package cn.cqu.coce.xutao;

 

public class zhijiecharu {

 public static void main(String args[]){

 int a[]={1,2,34,67,8,9,6,7,56,34,232,99};
 int i,j,k;
 for(i=0;i<a.length;i++)
  System.out.print(a[i]+"\t");
 System.out.println();
 for(i=1;i<a.length;i++){

  for(j=i-1;j>=0;j--)
   if(a[i]>a[j])
    break;

  if(j!=i-1){
   int temp;
   temp=a[i];
   for(k=i-1;k>j;k--)
    a[k+1]=a[k];
   a[k+1]=temp;  
  }  
 }
 for(i=0;i<a.length;i++)
  System.out.print(a[i]+"\t");
 System.out.println();
  }
}



java直接插入排序示例

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲日本aⅴ片在线观看香蕉 | 色多多视频在线 | 久久精品动漫99精品动漫 | 人人爽人人草 | 本站只有精品 | 精品久久久久久久久久久 | 日韩在线观看一区二区不卡视频 | 日本一区二区免费在线观看 | 门卫老张和女警花小说 | 全黄h全肉细节文在线观看 全彩成人18h漫画 | 亚洲成人综合在线 | 日韩高清无砖砖区2022 | 啊啊啊好大好爽视频 | 欧美国产在线 | 国产yw193.㎝m在线观看 | 国产成人无精品久久久 | 国产高清在线看 | 羞羞在线观看 | 国产麻豆剧果冻传媒影视4934 | 男女激情视频1000辣妞范 | 亚洲精品第五页中文字幕 | 日本加勒比在线精品视频 | 99在线视频精品 | 亚洲 欧美 日韩 国产 视频 | 9久re在线观看视频精品 | 国产福利资源 | 91国内精品 | 日本三级在丈面前被耍了 | 成人精品第一区二区三区 | 精品网站一区二区三区网站 | 日本中文字幕不卡在线一区二区 | 亚洲国产成人超福利久久精品 | 999国产高清在线精品 | 久久这里只有精品国产精品99 | 成人黄色a级片 | 欧美一级艳片视频免费观看 | 娇妻与公陈峰姚瑶最新版 | 色偷偷亚洲综合网亚洲 | 无敌秦墨漫画免费阅读 | 办公室里被迫高h | 日韩免费毛片视频杨思敏 |