- 相关推荐
冒泡排序算法原理及JAVA实现代码方法
冒泡排序算法原理及JAVA实现代码方法
冒泡排序法:关键字较小的`记录好比气泡逐趟上浮,关键字较大的记录好比石块下沉,每趟有一块最大的石块沉底。
算法本质:(最大值是关键点,肯定放到最后了,如此循环)每次都从第一位向后滚动比较,使最大值沉底,最小值上升一次,最后一位向前推进(即最后一位刚确定的最大值不再参加比较,比较次数减1)
复杂度: 时间复杂度 O(n2) ,空间复杂度O(1)
JAVA源代码(成功运行,需要Date类)
复制代码 代码如下:
public static void bubbleSort(Date[] days) {
int len = days.length;
Date temp;
for (int i = len - 1; i >= 1; i--) {
for (int j = 0; j < i; j++) {
if (days[j].compare(days[j + 1]) > 0) {
temp = days[j + 1];
days[j + 1] = days[j];
days[j] = temp;
}
}
}
}
class Date {
int year, month, day;
Date(int y, int m, int d) {
year = y;
month = m;
day = d;
}
public int compare(Date date) {
return year > date.year ? 1 : year < date.year ? -1
: month > date.month ? 1 : month < date.month ? -1
: day > date.day ? 1 : day < date.day ? -1 : 0;
}
public void print() {
System.out.println(year + " " + month + " " + day);
}
}
【冒泡排序算法原理及JAVA实现代码方法】相关文章:
C语言的冒泡排序方法08-22
java的常见排序方法08-31
C语言选择排序算法及实例代码07-25
C语言插入排序算法及实例代码07-02
教你JAVA语言快速排序的原理10-04
java构造函数实现代码示例08-23
java通用组合算法如何实现09-12
C#实现协同过滤算法的实例代码06-19
Java常用的五大排序算法09-09
关于Java动态实现的方法08-23