程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> java數據構造與算法之奇偶排序算法完全示例

java數據構造與算法之奇偶排序算法完全示例

編輯:關於JAVA

java數據構造與算法之奇偶排序算法完全示例。本站提示廣大學習愛好者:(java數據構造與算法之奇偶排序算法完全示例)文章只能為提供參考,不一定能成為您想要的結果。以下是java數據構造與算法之奇偶排序算法完全示例正文


本文實例講述了java數據構造與算法之奇偶排序算法。分享給年夜家供年夜家參考,詳細以下:

算法思惟:

根本思緒是奇數列排一趟序,偶數列排一趟序,再奇數排,再偶數排,直到全體有序

舉例吧,

待排數組[6 2 4 1 5 9]

第一次比擬奇數列,奇數列與它的鄰人偶數列比擬,如6和2比,4和1比,5和9比

[6 2 4 1 5 9]

交流後釀成

[2 6 1 4 5 9]

 第二次比擬偶數列,即6和1比,5和5比

[2 6 1 4 5 9]

交流後釀成

[2 1 6 4 5 9]

 第三趟又是奇數列,選擇的是2,6,5分離與它們的鄰人列比擬

[2 1 6 4 5 9]

交流後

[1 2 4 6 5 9]

 第四趟偶數列

[1 2 4 6 5 9]

一次交流

[1 2 4 5 6 9]

詳細代碼:

public class Main {
  /**
   * @param args the command line arguments
   */
  public static void main(String[] args) {
    int[] numbers = new int[]{12,33,45,33,13,55,34,7,6};
    Main.oddEventSort(numbers);
    for(int i=0; i<numbers.length; i++){
      System.out.print(numbers[i]+" ");
    }
  }
  private static void oddEventSort(int[] numbers){
    int temp;
    for(int i=numbers.length-1; i>numbers.length/2-1; i--){
      for(int j=1; j<=i; j+=2){
        if(j==numbers.length-1)break;
        if(numbers[j]>numbers[j+1]){
          temp = numbers[j];
          numbers[j] = numbers[j+1];
          numbers[j+1] = temp;
        }
      }
      for(int j=0; j<=i; j+=2){
        if(j==numbers.length-1)break;
        if(numbers[j]>numbers[j+1]){
          temp = numbers[j];
          numbers[j] = numbers[j+1];
          numbers[j+1] = temp;
        }
      }
    }
  }
}

PS:聽說在多核時期這個算法比擬好用

願望本文所述對年夜家java法式設計有所贊助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved