java算法:选择排序

java算法:选择排序

选择排序:找数组中的最小元素与第一个位置的元素比较交换,然后找第二个最小的元素并与第二个位置的元素比较交换,一直进行下去,直到整个数组排序完毕。

如,对EXAMPLE 字母进行排序:

 
 E   X   A   M   P   L   E
[A]  X   E   M   P   L   E 第一位置最小值A
[A] [E]  X   M   P   L   E 第二位置剩下最小值E
[A] [E] [E]  M   P   L   X 第三位置剩下最小值E
[A] [E] [E] [L]  P   M   X ...
[A] [E] [E] [L] [M]  P   X
[A] [E] [E] [L] [M] [P]  X
[A] [E] [E] [L] [M] [P] [X]

Java代码 复制代码
  1. public interface Item{   
  2.     boolean less(Item v);   
  3. }  
public interface Item{
	boolean less(Item v);
}
Java代码 复制代码
  1. public class MyItem implements Item{   
  2.     private int key;   
  3.     public boolean less(Item v){   
  4.         return key < ((MyItem)v).key;   
  5.     }   
  6.     public void read(){   
  7.         key = new Random().nextInt();   
  8.     }   
  9.     public void rand(){   
  10.         key = (int)(1000 * Math.random());   
  11.     }   
  12.     public String toString(){   
  13.         return key + "";   
  14.     }   
  15. }  
public class MyItem implements Item{
	private int key;
	public boolean less(Item v){
		return key < ((MyItem)v).key;
	}
	public void read(){
		key = new Random().nextInt();
	}
	public void rand(){
		key = (int)(1000 * Math.random());
	}
	public String toString(){
		return key + "";
	}
}
Java代码 复制代码
  1. public class Selection {   
  2.   
  3.     public static void main(String[] args) {   
  4.         int n = 60;   
  5.         MyItem [] a = new MyItem[n];   
  6.         for (int i = 0; i < n; i++) {   
  7.             a[i] = new MyItem();   
  8.             a[i].rand();   
  9.         }   
  10.            
  11.         for (int i = 0; i < n; i++) {   
  12.             System.out.print(a[i] + " ");   
  13.         }   
  14.            
  15.         selection(a, 0, n);   
  16.         System.out.println("");   
  17.         print(a, n);   
  18.     }   
  19.        
  20.     private static void print(MyItem a [], int n){   
  21.         for (int i = 0; i < n; i++) {   
  22.             System.out.print(a[i] + " ");   
  23.         }   
  24.     }   
  25.        
  26.     public static void selection(MyItem [] a, int l, int r){   
  27.         for (int i = l; i < r; i++) {   
  28.             int min = i;   
  29.             for (int j = i + 1; j < r; j++) {   
  30.                 if(less(a[j], a[min])){   
  31.                     min = j;   
  32.                 }   
  33.             }   
  34.             exch(a, i, min);   
  35.         }   
  36.     }   
  37.        
  38.     public static boolean less(Item v, Item w){   
  39.         return v.less(w);   
  40.     }   
  41.        
  42.     public static void exch(Item [] a, int i, int j){   
  43.         Item t = a[i];   
  44.         a[i] = a[j];   
  45.         a[j] = t;   
  46.     }   
  47.        
  48.     public static void compExch(Item [] a, int i, int j){   
  49.         if(less(a[j],a[i])){   
  50.             exch(a, i, j);   
  51.         }   
  52.     }   
  53. }  
public class Selection {

	public static void main(String[] args) {
		int n = 60;
		MyItem [] a = new MyItem[n];
		for (int i = 0; i < n; i++) {
			a[i] = new MyItem();
			a[i].rand();
		}
		
		for (int i = 0; i < n; i++) {
			System.out.print(a[i] + " ");
		}
		
		selection(a, 0, n);
		System.out.println("");
		print(a, n);
	}
	
	private static void print(MyItem a [], int n){
		for (int i = 0; i < n; i++) {
			System.out.print(a[i] + " ");
		}
	}
	
	public static void selection(MyItem [] a, int l, int r){
		for (int i = l; i < r; i++) {
			int min = i;
			for (int j = i + 1; j < r; j++) {
				if(less(a[j], a[min])){
					min = j;
				}
			}
			exch(a, i, min);
		}
	}
	
	public static boolean less(Item v, Item w){
		return v.less(w);
	}
	
	public static void exch(Item [] a, int i, int j){
		Item t = a[i];
		a[i] = a[j];
		a[j] = t;
	}
	
	public static void compExch(Item [] a, int i, int j){
		if(less(a[j],a[i])){
			exch(a, i, j);
		}
	}
}

选择排序的缺点是它的运行时间与文件中已排序的数量几乎没有关系。寻找最小元素的一次遍历并不能提供多少关于下一次遍历文件时最小元素位置的信息。可以看到,使用选择排序所花费的时间不管对于随机或已排好都是差不多。不能很好的利用文件中的有序性。

转载于:https://www.cnblogs.com/wuyida/archive/2012/11/01/6301138.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值