温习以前的算法,每天来一点,希望能坚持
1、冒泡排序
最简单的排序算法,思想:将数组遍历n-1次,每次选出最大的元素放在队尾。
直接上代码:
package sort;
public class TestSort {
public static void main(String []args){
int b[] = {5,3,12,4,78,6,10,33};
int result[]= bubbleSort(b);
for(int i=0;i<result.length;i++){
System.out.print(result[i] +",");
}
}
public static int[] bubbleSort(int a[]){
for(int i=a.length-1;i>=0;i--){
for(int j=0;j<i;j++){
if(a[j]>a[j+1]){
int temp = a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
}
}
return a;
}
}
2、选择排序
思想:每次从未排序的队列中选出最小的一个,放在已排序的末尾。
代码:
/**
* 选择排序
* @param a
* @return
*/
public static int[] selectSort(int a[]){
for(int i=0 ; i<a.length;i++){
for(int j=i+1;j<a.length;j++){
if(a[i]>a[j]){
int temp = a[i];
a[j]=a[i];
a[i]=temp;
}
}
}
return a;
}