2015-02-24
选择排序:
首先,找到数组中最小的那个元素
其次,将它和数组的第一个元素交换位置(如果第一个元素就是最小元素,那么他就和自己交换)
再次:在剩下的元素中找到最小的元素,将它与数组的第二个元素交换位置。
如此往复,直到将整个数组排序。这种方法叫做选择排序
不断的选择剩余元素之中的最小者
package algorithms;
publicclass Sort {
privatestaticboolean less(Comparable v,Comparable w){
returnv.compareTo(w)<0;
}
privatestaticvoid exch(Comparable[] a,inti,intj){
Comparablet = a[i];
a[i] = a[j];
a[j] = t;
}
privatestaticvoid show(Comparable[] a) {
for(inti=0;i<a.length;i++){
System.err.print(a[i]+" ");
}
System.err.println();
}
privatestaticboolean isSorted(Comparable[] a) {
for(inti=1;i<a.length-1;i++){
if(less(a[i],a[i-1])){
returnfalse;
}
}
returntrue;
}
//选择排序
publicstaticvoid selectSort(Comparable[] a) {
for(inti=0;i<a.length;i++){
//将a[i]和a[i+1..a.length]中最小的元素交换
intmin = i;//最小元素的索引
for(intj=i+1;j<a.length;j++){
if(less(a[j],a[min])){
min = j;
}
exch(a, i, min);
}
}
}
//冒泡排序
privatestaticvoid BubbleSort(int[] a) {
inttemp=0;
for(inti=0;i<a.length-1;i++){
for(intj=0;j<a.length-1-i;j++){
if(a[j+1]<a[j]){
temp = a[j];
a[j] = a[j+1];
a[j+1] = temp;
}
}
}
}
publicstaticvoid main(String[] args) {
String[]a = {"3","6","5","4","1","9","8","7","2"};
selectSort(a);
System.err.print("选择排序:");
assert isSorted(a);
show(a);
System.err.println("------------------------");
int[] b = {3,6,5,4,1,9,8,7,2};
BubbleSort(b);
System.err.print("冒泡排序:");
for(inti=0;i<b.length;i++){
System.err.print(b[i]+" ");
}
System.err.println();
}
}
没那么麻烦,粘上就能用,听说一般公司算法也就考考冒泡和快速。我听说的哈,别喷我