Java冒泡排序算法详解
冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来,遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成,这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。
以下是一个简单的Java实现冒泡排序的例子:
public class BubbleSort { public static void main(String[] args) { int[] arr = {3, 9, -1, 10, 20}; bubbleSort(arr); System.out.println("排序后的数组为:"); for (int i = 0; i < arr.length; i++) { System.out.print(arr[i] + " "); } } public static void bubbleSort(int[] arr) { int temp; boolean flag; for (int i = 0; i < arr.length - 1; i++) { flag = false; for (int j = 0; j < arr.length - 1 - i; j++) { if (arr[j] > arr[j + 1]) { temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; flag = true; } } if (!flag) { break; } } } }
在这个例子中,我们首先定义了一个整数数组arr
,然后调用bubbleSort
方法对其进行排序,在bubbleSort
方法中,我们使用两层循环来实现冒泡排序,外层循环控制遍历次数,内层循环进行相邻元素的比较和交换,如果在一次遍历中没有发生交换,说明数组已经排序完成,可以提前结束循环,我们打印出排序后的数组。
还没有评论,来说两句吧...