亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

Java--------數組排序

標簽:
Java

Java数组的三种排序方法
1.插入排序:

public class InsertSortDemo {

public static void main(String[] args) {
    // TODO Auto-generated method stub
    int[] arr={12,9,33,45,33,21,8,0,66,83,38};
    for(int i=1;i<arr.length;i++)
    {
        for(int j=0;j<=i-1;j++)
        {
            if(arr[j]>arr[i]) //说明当前元素比要插入的元素大,则在该位置插入元素
            {
                //首先把要插入的元素保存下来,否则移动完,元素就没有了。
                int temp = arr[i];
                //从插入的位置开始,向后移动元素
                for(int k=i;k>=j+1;k--) //一定要从后往前移动,否则元素会丢失。
                {
                    arr[k]=arr[k-1];
                }
                arr[j]=temp;//插入元素。
            }   
        }
    }
    System.out.println("--------排序之后----------");
    for(int i=0;i<arr.length;i++)
    {
        System.out.print(arr[i]+" ");
    }
}

}

2.冒泡排序:
//冒泡排序算法,属于交换排序的一种
public class PopSortDemo {

public static void main(String[] args) {
    // TODO Auto-generated method stub 
    int[] arr={12,9,33,45,33,21,8,0,66,83,38};
    for(int i=arr.length-2;i>=0;i--)
    {
        for(int j=0;j<=i;j++)
        {
            if(arr[j]>arr[j+1])//左边比右边大
            {
                int temp;
                temp = arr[j];
                arr[j]=arr[j+1];
                arr[j+1]=temp;
            }
        }
    }
    System.out.println("-----排序之后--------");
    for(int i=0;i<arr.length;i++)
    {
        System.out.print(arr[i]+" ");
    }
}

}

3.选择排序:
public class SelectedSortDemo {

public static void main(String[] args) {
    int[] arr={12,9,33,45,33,21,8,0,66,83,38};
    int pos;//最小元素的下标;
    int min;//保存最小元素
    for(int i=0;i<arr.length;i++)
    {
        pos=i; //先让最小元素下标等于i;
        min = arr[pos];
        for(int j=i+1;j<arr.length;j++)
        {
            if(arr[j]<min) //说明找到一个更小的元素
            {
                min = arr[j];
                pos = j; //记住下标;
            }
        }
        //交换元素
        if(pos!=i)//如果找到的最小下标不是第一个下标
        {
          int temp;
          temp = arr[i];
          arr[i] = arr[pos];
          arr[pos] = temp;
        }
    }
    System.out.println("-------排序之后-------");
    for(int i=0;i<arr.length;i++)
    {
        System.out.print(arr[i]+" ");
    }
}

}

點擊查看更多內容
12人點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
JAVA開發工程師
手記
粉絲
1.5萬
獲贊與收藏
8507

關注作者,訂閱最新文章

閱讀免費教程

感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消