程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> 深刻Java冒泡排序與選擇排序的差別詳解

深刻Java冒泡排序與選擇排序的差別詳解

編輯:關於JAVA

深刻Java冒泡排序與選擇排序的差別詳解。本站提示廣大學習愛好者:(深刻Java冒泡排序與選擇排序的差別詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是深刻Java冒泡排序與選擇排序的差別詳解正文


冒泡排序
它反復地訪問過要排序的數列,一次比擬兩個元素,假如他們的次序毛病就把他們交流過去。訪問數列的任務是反復地停止直到沒有再須要交流,也就是說該數列曾經排序完成。
代碼以下:

public class nums {
     public static void main(String[] args){
         int []nums = {5,4,3,2,1};
         for(int i = 0; i < nums.length; i++){
             for(int j = 0; j < nums.length-i-1; j++){
                 if(nums[j] > nums[j+1]){
                     int temp = nums[j];
                     nums[j] = nums[j+1];
                     nums[j+1] = temp;
                 }
             }
             for(int x = 0;x < nums.length;x++){
                  System.out.print(nums[x]+",");
              }
             System.out.print("\n");
         }
     }
 }

每輪比擬後的輸入以下:

1 4,3,2,1,5,
2 3,2,1,4,5,
3 2,1,3,4,5,
4 1,2,3,4,5,
5 1,2,3,4,5,

從輸入中可以很清晰的明確冒泡排序的算法流程。
選擇排序
每趟從待排序的數據元素當選出最小(或最年夜)的一個元素,次序放在已排好序的數列的最初,直到全體待排序的數據元素排完。
代碼以下:

public class nums {
     public static void main(String[] args){
         int []nums = {5,4,3,2,1};
         for(int i = 0; i < nums.length; i++){
             for(int j = 0; j < nums.length; j++){
                 if(nums[i] < nums[j]){
                     int temp = nums[i];
                     nums[i] = nums[j];
                     nums[j] = temp;
                 }
             }
             for(int x = 0;x < nums.length;x++){
                  System.out.print(nums[x]+",");
              }
             System.out.print("\n");
         }
     }
 }

從代碼中可以看出每輪比擬中,nums[i]和數組中的每一個元素都有作比擬。
每輪比擬後的輸入以下:

1 5,4,3,2,1,
2 4,5,3,2,1,
3 3,4,5,2,1,
4 2,3,4,5,1,
5 1,2,3,4,5,

從輸入成果中照樣很輕易看出它與冒泡排序在算法上的差別。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved