package com.tju.sort;
/**
* Created by xiangyang.laixiang on 2016/8/2.
*/
public class SelectionSort {
public static int getMinKey(int a[], int count, int from){
int minKey = from;
for(int i=from+1;i<count;i++)
{
if(a[i]<a[minKey])
{
minKey = i;
}
}
return minKey;
}
public static void selectSort(int a[], int n)
{
int minKey = 0;
for (int i=0;i<n-1;i++)
{
minKey=i;
int key = getMinKey(a,n,i+1);
if(minKey != key)
{
int temp=a[minKey];
a[minKey] = a[key];
a[key]=temp;
}
}
}
public static void main(String[] args)
{
int a[]={6,1,2,7,8,9,3,6};
selectSort(a,a.length);
for (int value : a)
{
System.out.println(value);
}
}
}
选择排序
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 选择排序 对于任何输入,时间为O(n*n); 冒泡排序 最优(对于升序的数组,因为加入了一个跳出判断):O(n),...
- 基本思想 数组分成有序区和无序区,初始时整个数组都是无序区,然后每次从无序区选一个最小的元素直接放到有序区的最后,...
- 给定数组 int[] arr = {3,6,8,4,7,5,9,1,2,0};使用至少三种方法对数组arr排序(作...
- 用Objective-C实现几种基本的排序算法,并把排序的过程图形化显示。其实算法还是挺有趣的 ^ ^. 选择排序...