冒泡排序
冒泡排序比较好理解,但是效率比较低,
冒泡排序的基本思想是:每一次将最具有特征的一个数(或者object)放到序列的最前面,或者最后面。
例如,如果需要将一组数,以从小到大的顺序排列,那么就可以设计这样的冒泡方法:可以设计从序列的最后面开始,找出序列中最小的一个数放到序列的最前面,这样经过n次循环也可以实现数组的排列。这种排序方法由于每一次找到的数字都像是气泡一样从数组里冒出来而得名为“冒泡排序”。
Java代码 收藏代码
public void bubbleSort(int[] array) {
int temp;
// 第一层循环: 表明要比较的次数,比如list.count个数,肯定要比较count-1次
for (int i = 0; i < array.length - 1; i++) {
// list.count-1:取数据最后一个数下标,
// j>i: 从后往前的的下标一定大于从前往后的下标,否则就超越了。
for (int j = array.length - 1; j > i; j--) {
// 如果前面一个数大于后面一个数则交换
if (array[j - 1] > array[j]) {
temp = array[j - 1];
array[j - 1] = array[j];
array[j] = temp;
}
}
}
}
选择排序
Java代码 收藏代码
//选择排序
public void selectSort(int [] a) {
int n = a.length;
for(int k=0; k<n-1; k++) {
int min = k;
for(int i=k+1; i<n; i++) {
if(a[i] < a[min]) {
min = i;
}
}
if(k != min) {
int temp = a[k];
a[k] = a[min];
a[min] = temp;
}
}
}
完整可执行代码:
Java代码 收藏代码
package sort;
import java.util.Date;
import java.util.Random;
import org.junit.Test;
public class BubbleSort {
Random random = new Random();
int[] array = new int[2000];
public void init(int [] a) {
for (int j = 0; j < 2000; j++) {
a[j] = random.nextInt(100000);
}
}
@Test
public void bubbleSortTest() {
init(array);
Date dateStart = new Date();
bubbleSort(array);
Date dateEnd = new Date();
System.out.println("冒泡排序耗费时间:"
+ (dateEnd.getTime() - dateStart.getTime()));
log(array,10);
System.out.println("冒泡排序耗费时间:"
+ (dateEnd.getTime() - dateStart.getTime()));
}
@Test
public void selectSortTest() {
init(array);
Date dateStart = new Date();
selectSort(array);
Date dateEnd = new Date();
System.out.println("选择排序耗费时间:"
+ (dateEnd.getTime() - dateStart.getTime()));
log(array,10);
System.out.println("选择排序耗费时间:"
+ (dateEnd.getTime() - dateStart.getTime()));
}
public void log(int [] a, int top) {
for(int i=0; i<top; i++) {
System.out.print(a[i] + ",");
}
}
public void bubbleSort(int[] array) {
int temp;
// 第一层循环: 表明要比较的次数,比如list.count个数,肯定要比较count-1次
for (int i = 0; i < array.length - 1; i++) {
// list.count-1:取数据最后一个数下标,
// j>i: 从后往前的的下标一定大于从前往后的下标,否则就超越了。
for (int j = array.length - 1; j > i; j--) {
// 如果前面一个数大于后面一个数则交换
if (array[j - 1] > array[j]) {
temp = array[j - 1];
array[j - 1] = array[j];
array[j] = temp;
}
}
}
}
//选择排序
public void selectSort(int [] a) {
int n = a.length;
for(int k=0; k<n-1; k++) {
int min = k;
for(int i=k+1; i<n; i++) {
if(a[i] < a[min]) {
min = i;
}
}
if(k != min) {
int temp = a[k];
a[k] = a[min];
a[min] = temp;
}
}
}
冒泡排序比较好理解,但是效率比较低,
冒泡排序的基本思想是:每一次将最具有特征的一个数(或者object)放到序列的最前面,或者最后面。
例如,如果需要将一组数,以从小到大的顺序排列,那么就可以设计这样的冒泡方法:可以设计从序列的最后面开始,找出序列中最小的一个数放到序列的最前面,这样经过n次循环也可以实现数组的排列。这种排序方法由于每一次找到的数字都像是气泡一样从数组里冒出来而得名为“冒泡排序”。
Java代码 收藏代码
public void bubbleSort(int[] array) {
int temp;
// 第一层循环: 表明要比较的次数,比如list.count个数,肯定要比较count-1次
for (int i = 0; i < array.length - 1; i++) {
// list.count-1:取数据最后一个数下标,
// j>i: 从后往前的的下标一定大于从前往后的下标,否则就超越了。
for (int j = array.length - 1; j > i; j--) {
// 如果前面一个数大于后面一个数则交换
if (array[j - 1] > array[j]) {
temp = array[j - 1];
array[j - 1] = array[j];
array[j] = temp;
}
}
}
}
选择排序
每一趟从待排序的数据元素中选出最小(或最大)的一个元素,顺序放在已排好序的数列的最后,直到全部待排序的数据元素排完。

Java代码 收藏代码
//选择排序
public void selectSort(int [] a) {
int n = a.length;
for(int k=0; k<n-1; k++) {
int min = k;
for(int i=k+1; i<n; i++) {
if(a[i] < a[min]) {
min = i;
}
}
if(k != min) {
int temp = a[k];
a[k] = a[min];
a[min] = temp;
}
}
}
完整可执行代码:
Java代码 收藏代码
package sort;
import java.util.Date;
import java.util.Random;
import org.junit.Test;
public class BubbleSort {
Random random = new Random();
int[] array = new int[2000];
public void init(int [] a) {
for (int j = 0; j < 2000; j++) {
a[j] = random.nextInt(100000);
}
}
@Test
public void bubbleSortTest() {
init(array);
Date dateStart = new Date();
bubbleSort(array);
Date dateEnd = new Date();
System.out.println("冒泡排序耗费时间:"
+ (dateEnd.getTime() - dateStart.getTime()));
log(array,10);
System.out.println("冒泡排序耗费时间:"
+ (dateEnd.getTime() - dateStart.getTime()));
}
@Test
public void selectSortTest() {
init(array);
Date dateStart = new Date();
selectSort(array);
Date dateEnd = new Date();
System.out.println("选择排序耗费时间:"
+ (dateEnd.getTime() - dateStart.getTime()));
log(array,10);
System.out.println("选择排序耗费时间:"
+ (dateEnd.getTime() - dateStart.getTime()));
}
public void log(int [] a, int top) {
for(int i=0; i<top; i++) {
System.out.print(a[i] + ",");
}
}
public void bubbleSort(int[] array) {
int temp;
// 第一层循环: 表明要比较的次数,比如list.count个数,肯定要比较count-1次
for (int i = 0; i < array.length - 1; i++) {
// list.count-1:取数据最后一个数下标,
// j>i: 从后往前的的下标一定大于从前往后的下标,否则就超越了。
for (int j = array.length - 1; j > i; j--) {
// 如果前面一个数大于后面一个数则交换
if (array[j - 1] > array[j]) {
temp = array[j - 1];
array[j - 1] = array[j];
array[j] = temp;
}
}
}
}
//选择排序
public void selectSort(int [] a) {
int n = a.length;
for(int k=0; k<n-1; k++) {
int min = k;
for(int i=k+1; i<n; i++) {
if(a[i] < a[min]) {
min = i;
}
}
if(k != min) {
int temp = a[k];
a[k] = a[min];
a[min] = temp;
}
}
}
}
jiaozhiguang-126-com.iteye.com/blog/1679040
本文介绍了两种基本排序算法——冒泡排序和选择排序,并通过Java代码实现这两种算法。冒泡排序通过不断交换相邻的未正确排序的元素来工作,而选择排序则是每次从未排序的部分找出最小元素并放到已排序部分的末尾。
2064

被折叠的 条评论
为什么被折叠?



