欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

JAVA排序算法--选择排序

程序员文章站 2024-02-23 08:13:04
...
选择排序的思想是 先拿出数组里的第一个数a[0] 用后面的每一个数一次和它比较 如果发现有比a[0]大(我们以升序为例) 就记录这个数的下标lowerIndex 请注意 并没有交换两个数的位置 再继续往后遍历 用后面的数和a[lowerIndex]比较大小 同理 若比a[lowerIndex]小 就把这个数的下标赋值给lowerIndex 知道内层循环结束 即把整个数组中最小的数找到了 并放在了第一个位置 注意 这时候 其他数的位置并没有发生变化 然后跳出到外层循环 i++ 继续执行下一次遍历
以下是具体实现代码。。



/**
* JAVA排序算法--选择排序
*
* @author 千醉 JAVA新手菜鸟群 32413139
*
*/
public class Test {

public static void SelectSort(int a[]) {
int i, j, k; // 循环计数变量
int lowerIndex; // 最小值索引变量
int temp; // 暂存变量

for (i = 0; i < a.length ; i++) {
lowerIndex = i; // 储存最小数值的索引值
for (j = i+1; j < a.length; j++) {
if (a[j] < a[lowerIndex]) // 找到最小值 注意此处不是判断a[j]<a[i]
lowerIndex = j ;
}
if(i!=lowerIndex)//交换两数 即 把当前未排序的剩余数中把选择出来的最小的放到i的位置上
{
temp = a[i] ;
a[i] = a[lowerIndex] ;
a[lowerIndex] = temp ;
}
System.out.print("排序中: ");
for (k = 0; k < a.length; k++)
System.out.printf("%3s", a[k]);
System.out.println("");
}
}

public static void main(String args[]) {
int[] a = { 10, 32, 1, 9, 5, 7, 12, 0, 4, 3 }; // 预设数据数组
int i; // 循环计数变量


System.out.print("排序前: ");
for (i = 0; i < a.length ; i++)
System.out.printf("%3s", a[i]);
System.out.println("");

SelectSort(a); // 选择排序
// 排序后结果
System.out.print("排序后: ");
for (i = 0; i < a.length ; i++)
System.out.printf("%3s", a[i]);
System.out.println("");
}
}



运行结果:

排序前: 10 32 1 9 5 7 12 0 4 3
排序中: 0 32 1 9 5 7 12 10 4 3
排序中: 0 1 32 9 5 7 12 10 4 3
排序中: 0 1 3 9 5 7 12 10 4 32
排序中: 0 1 3 4 5 7 12 10 9 32
排序中: 0 1 3 4 5 7 12 10 9 32
排序中: 0 1 3 4 5 7 12 10 9 32
排序中: 0 1 3 4 5 7 9 10 12 32
排序中: 0 1 3 4 5 7 9 10 12 32
排序中: 0 1 3 4 5 7 9 10 12 32
排序中: 0 1 3 4 5 7 9 10 12 32
排序后: 0 1 3 4 5 7 9 10 12 32
相关标签: 算法 Java J#