算法描述:對于給定的一個數(shù)組,初始時假設(shè)第一個記錄自成一個有序序列,其余記錄為無序序列。接著從第二個記錄開始,按照記錄的大小依次將當前處理的記錄插入到其之前的有序序列中,直至最后一個記錄插入到有序序列中為止。
創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、成都網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的尼元陽網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!直接插入排序Java實現(xiàn)教程
示例1
public class Insert { public static void main(String[] args) { int a[] = {9,3,28,6,34,7,10,27,1,5,8}; show(a); for (int i=1;i insertOne(a, i); } show(a); } static void show(int a[]){ for (int i=0;i System.out.print(a[i]+" "); } System.out.println(); } //把第k個元素融入到前面有序隊列 static void insertOne(int a[],int k){ for (int i=0;i<=k;i++){ if(a[i]>=a[k]){ int temp = a[k]; //移動之前先把a[k]放到一個中間變量處 //從k位置前面的數(shù)依次往后移動,直到i位置 for (int j=k-1;j>=i;j--){ a[j+1] = a[j]; } a[i] = temp; //把中間變量中的值給a[i],移動之后i處的值為空。 } } } }