欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-02-22 19:48:34
冒泡排序法:关键字较小的记录好比气泡逐趟上浮,关键字较大的记录好比石块下沉,每趟有一块最大的石块沉底。 算法本质:(最大值是关键点,肯定放到最后了,如此循环)每次都从第一...

冒泡排序法:关键字较小的记录好比气泡逐趟上浮,关键字较大的记录好比石块下沉,每趟有一块最大的石块沉底。

算法本质:(最大值是关键点,肯定放到最后了,如此循环)每次都从第一位向后滚动比较,使最大值沉底,最小值上升一次,最后一位向前推进(即最后一位刚确定的最大值不再参加比较,比较次数减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);
 }
}

复制代码 代码如下:

package testsortalgorithm;

public class bubblesort {
 public static void main(string[] args) {
  int array[] = { 5, 6, 8, 4, 2, 4, 9, 0 };
  bubblesort(array);
  for (int i = 0; i < array.length; i++) {
   system.out.println(array[i]);
  }
 }

 public static void bubblesort(int array[]) {
  int temp;
  for (int i = array.length - 1; i > 0; i--) {
   for (int j = 0; j < i; j++) {
    if (array[j] > array[j + 1]) {
     temp = array[j];
     array[j] = array[j + 1];
     array[j + 1] = temp;
    }
   }
  }
 }
}