选择排序的原理:
对比数组中前一个元素跟后一个元素的大小,如果后面的元素比前面的元素小则用一个变量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]);
}
}
}