选择排序的原理:

对比数组中前一个元素跟后一个元素的大小,如果后面的元素比前面的元素小则用一个变量min来记住他的位置,接着第二次比较,前面“后一个元素”现变成了“前一个元素”,继续跟他的“后一个元素”进行比较如果后面的元素比他要小则用变量k记住它在数组中的位置(下标),等到循环结束的时候,我们应该找到了最小的那个数的下标了,然后进行判断,如果这个元素的下标不是第一个元素的下标,就让第一个元素跟他交换一下值,这样就找到整个数组中最小的数了。然后找到数组中第二小的数,让他跟数组中第二个元素交换一下值,以此类推。

C语言代码:

#include<stdio.h>
//选择排序
int main(){
int i, j, min, temp, arr[6] = {3,2,6,9,4,7};
for(i = 0; i < 5; i++){
    min = i;
    for(j = i + 1; j < 6; j++){
        if(arr[min] > arr[j]){
            min = j;
        }
    }
    if(min != i){
        temp = arr[min];
        arr[min] = arr[i];
        arr[i] = temp;
    }
}
printf("排序后的数字 :");
for(i = 0; i < 6; i++){
    if(i == 5){
        printf("%d",arr[i]);
    }else{
        printf("%d,",arr[i]);
    }
}
return 0;
}

Java代码:

public static void main(String[] args){
int arr[] = {3,2,6,9,4,7};
   for (int i = 0; i < arr.length - 1; i++) {
        int  min = i;
        for (int j = i + 1; j < arr.length; j++) {
              if (arr[min] > arr[j]) {
                   min = j;
              }
        }
        if (min != i) {
           int tmp = arr[min];
           arr[min] = arr[i];
           arr[i] = tmp;
        }
  }
   System.out.print("排序后的数字:");
   for(int i = 0; i < arr.length; i++){
       if(i == arr.length){
           System.out.print(arr[i]);
       }else{
           System.out.print(arr[i]);
       }
   }
}
最后修改:2020 年 04 月 12 日 08 : 11 PM