亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java選擇排序法以及實例詳解

 更新時間:2022年11月06日 10:44:37   作者:bjpowernode  
在本篇文章里小編給大家整理了一篇關于Java選擇排序法以及實例內(nèi)容,并做了詳細分析,有興趣的朋友們可以跟著學習下。

選擇排序技術是一種選擇數(shù)組中最小的元素并與數(shù)組的第一個元素交換的方法。接下來,數(shù)組中第二小的元素與第二個元素交換,反之亦然。

這樣,數(shù)組中的最小元素會被重復選擇并放在適當?shù)奈恢?,直到整個數(shù)組被排序。

為選擇排序維護了兩個子數(shù)組:

排序子數(shù)組:在每次迭代中,找到最小元素并將其放置在適當?shù)奈恢?。該子?shù)組已排序。

未排序的子數(shù)組:未排序的剩余元素。

選擇排序是一種簡單明了的排序技術。該技術只涉及在每次傳遞中找到最小的元素并將其放置在正確的位置。選擇排序非常適合較小的數(shù)據(jù)集,因為它可以有效地對較小的數(shù)據(jù)集進行排序。

因此,我們可以說選擇排序不適用于較大的數(shù)據(jù)列表。

選擇排序算法

選擇排序的一般算法如下:

選擇排序 (A, N)

第 1 步:對 K = 1 到 N-1 重復第 2 步和第 3 步

第 2 步:最小調(diào)用例程(A,K,N,POS)

第 3 步:

用 A [POS] 交換 A[K]

[循環(huán)結束]

第 4 步:退出

例程最小(A、K、N、POS)

第 1 步:[初始化] 設置 minimumItem = A[K]

第 2 步:[初始化] 設置 POS = K

第 3 步:

對于 J = K+1 到 N -1,重復

if minimumItem > A [J]
set minimumItem = A [J]
set POS = J
[if end]
[End of loop]

第 4 步:返回 POS

如您所見,在遍歷數(shù)據(jù)集時調(diào)用了查找最小數(shù)字的例程。找到最小元素后,將其放置在所需位置。

Java中的選擇排序實現(xiàn)

現(xiàn)在讓我們演示實現(xiàn)選擇排序的 Java 程序。

import java.util.*;
class Main 
{ 
    static void sel_sort(int numArray[]) 
    { 
        int n = numArray.length;    
        // traverse unsorted array 
        for (int i = 0; i < n-1; i++) 
        { 
            // Find the minimum element in unsorted array 
            int min_idx = i; 
            for (int j = i+1; j < n; j++) 
                if (numArray[j] < numArray[min_idx]) 
                    min_idx = j;    
            // swap minimum element with compared element  
            int temp = numArray[min_idx]; 
            numArray[min_idx] = numArray[i]; 
            numArray[i] = temp; 
        } 
    }    
    public static void main(String args[]) 
    { 
        //declare and print the original array
        int numArray[] = {7,5,2,20,42,15,23,34,10};
        System.out.println("Original Array:" + Arrays.toString(numArray)); 
        //call selection sort routine
        sel_sort(numArray); 
        //print the sorted array
        System.out.println("Sorted Array:" + Arrays.toString(numArray)); 
    } 
} 

輸出:

原始數(shù)組:[7, 5, 2, 20, 42, 15, 23, 34, 10]
排序數(shù)組:[2, 5, 7, 10, 15, 20, 23, 34, 42]

知識點擴展:

冒泡排序法思路

1:外層循環(huán):控制它要走幾次。
假設你有5個數(shù),那就要走4次,最后一次不用走,最后那個數(shù)已經(jīng)在它位置了所以就要length-1次。
2:內(nèi)層循環(huán):控制逐一比較,如果發(fā)現(xiàn)前一個數(shù)比后一個數(shù)大,則交換。
注意!因為越比較長度就越小了,所以長度要length-1-i。

package com.test_1;

public class Demo5_3 {

  public static void main(String[] args) {
    // TODO Auto-generated method stub

    int arr [ ] ={1,6,0,-1,9};
    int temp=0;//中間值
    //-------冒泡排序法
    //外層循環(huán),它決定一共走幾趟
    for(int i = 0;i<arr.length-1;i++){
      //內(nèi)層循環(huán),開始逐個比較
      //如果我們發(fā)現(xiàn)前一個數(shù)比后一個數(shù)大,則交換
      for(int j=0;j<arr.length-1-i;j++){
        if (arr[j]>arr[j+1]) {
          //換位
          temp = arr[j];
          arr[j] = arr[j+1];
          arr[j+1] = temp;
        }
      }

    }
    //輸出結果
    for(int i = 0;i<arr.length;i++){
      System.out.print(arr[i]);
    }

  }

}

到此這篇關于Java選擇排序法以及實例詳解的文章就介紹到這了,更多相關Java選擇排序法和示例內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MyBatis核心配置文件深入分析

    MyBatis核心配置文件深入分析

    這篇文章主要介紹了MyBatis核心配置文件,MyBatis的前身就是iBatis,iBatis本是由Clinton Begin開發(fā),后來捐給Apache基金會,成立了iBatis開源項目。2010年5月該項目由Apahce基金會遷移到了Google Code,并且改名為MyBatis
    2022-12-12
  • Java synchronized關鍵字和Lock接口實現(xiàn)原理

    Java synchronized關鍵字和Lock接口實現(xiàn)原理

    這篇文章主要介紹了Java synchronized關鍵字和Lock接口實現(xiàn)原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12
  • SpringBoot啟動過程的實現(xiàn)

    SpringBoot啟動過程的實現(xiàn)

    這篇文章主要介紹了SpringBoot啟動過程的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • Java中Spring獲取bean方法小結

    Java中Spring獲取bean方法小結

    Spring是一個輕量級的控制反轉(IoC)和面向切面(AOP)的容器框架,如何在程序中獲取Spring配置的bean呢?下面通過本文給大家介紹Java中Spring獲取bean方法小結,對spring獲取bean方法相關知識感興趣的朋友一起學習吧
    2016-01-01
  • 一文詳解Spring構造函數(shù)推斷

    一文詳解Spring構造函數(shù)推斷

    這篇文章主要介紹了Spring構造函數(shù)推斷自動注入及底層原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加
    2023-04-04
  • springboot 配置使用swagger2操作

    springboot 配置使用swagger2操作

    這篇文章主要介紹了springboot 配置使用swagger2操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • spring?security?自定義Provider?如何實現(xiàn)多種認證

    spring?security?自定義Provider?如何實現(xiàn)多種認證

    這篇文章主要介紹了spring?security?自定義Provider實現(xiàn)多種認證方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java原生方法實現(xiàn) AES 算法示例

    Java原生方法實現(xiàn) AES 算法示例

    這篇文章主要介紹了Java原生方法實現(xiàn) AES 算法,結合實例形式分析了Java實現(xiàn)AES加密算法的相關操作技巧,需要的朋友可以參考下
    2019-03-03
  • IntelliJ Idea 2020.1 正式發(fā)布,官方支持中文(必看)

    IntelliJ Idea 2020.1 正式發(fā)布,官方支持中文(必看)

    這篇文章主要介紹了IntelliJ Idea 2020.1 正式發(fā)布,官方支持中文了,本文通過截圖的形式給大家展示,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • idea配置springboot熱部署終極解決辦法(解決熱部署失效問題)

    idea配置springboot熱部署終極解決辦法(解決熱部署失效問題)

    這篇文章主要介紹了idea配置springboot熱部署終極解決辦法(解決熱部署失效問題),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2020-07-07

最新評論