java语言

冒泡排序算法原理及JAVA实现代码方法

时间:2025-03-20 08:35:11 java语言 我要投稿
  • 相关推荐

冒泡排序算法原理及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实现代码方法】相关文章:

冒泡排序的原理以及java代码实现08-17

java常见的排序算法的代码09-20

Java 队列实现原理及简单实现代码09-13

JAVA简单选择排序算法及实现10-02

Java排序算法06-17

c#冒泡排序算法08-15

C语言冒泡排序算法实例06-15

java算法实现排列组合的方法介绍09-23

C语言快速排序算法及代码06-25