源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2020-11-17 05:04 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:冒泡排序算法原理及JAVA实现代码
[b]冒泡排序法[/b]:关键字较小的记录好比气泡逐趟上浮,关键字较大的记录好比石块下沉,每趟有一块最大的石块沉底。 算法本质:(最大值是关键点,肯定放到最后了,如此循环)每次都从第一位向后滚动比较,使最大值沉底,最小值上升一次,最后一位向前推进(即最后一位刚确定的最大值不再参加比较,比较次数减1) 复杂度: 时间复杂度 O(n2) ,空间复杂度O(1) JAVA源代码(成功运行,需要Date类)
[u]复制代码[/u] 代码如下:
 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);  } }
[u]复制代码[/u] 代码如下:
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;     }    }   }  } }
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部