要求:给定一个数组,让数组升序(降序)排序
思路:
假设升序排序:
①:将数组中相邻元素从前往后依次进行比较,如果前一个元素比后一个元素大,则交换,一趟下来后最大元素就在数组的末尾;
②:依次从①过程重复,直到数组中所有元素都排列好
冒泡排序图示:
java
import java.util.Arrays;
public class Test {
public static void main(String[] args) {
int[] arr = {9,5,2,7};
bubbleSort(arr);
System.out.println(Arrays.toString(arr));
}
public static void bubbleSort(int[] arr){
for (int i = 0; i < arr.length; i++) {
for (int j = 1; j < arr.length; j++) {
if(arr[j-1] > arr[j]){
int temp = arr[j-1];
arr[j-1] = arr[j];
arr[j] = temp;
}
}
}//end for
}//end bubbleSort
}
java
public class Test {
public static void main(String[] args) {
int[] arr = {9, 5, 2, 7};
bubbleSort(arr);
System.out.println(Arrays.toString(arr));
}
}
public class Test
: 定义了一个名为Test
的公共类。public static void main(String[] args)
: 主程序入口,main
方法是程序运行的起点。int[] arr = {9, 5, 2, 7};
: 初始化了一个整数数组arr
,包含 4 个元素:9, 5, 2, 7。bubbleSort(arr);
: 调用了bubbleSort
方法,对数组arr
进行排序。System.out.println(Arrays.toString(arr));
: 使用Arrays.toString(arr)
将排序后的数组转化为字符串并打印输出。
java
public static void bubbleSort(int[] arr){
for (int i = 0; i < arr.length; i++) {
for (int j = 1; j < arr.length; j++) {
if(arr[j-1] > arr[j]){
int temp = arr[j-1];
arr[j-1] = arr[j];
arr[j] = temp;
}
}
}
}
-
public static void bubbleSort(int[] arr
)
: 定义了一个名为bubbleSort
的静态方法,用来对传入的整数数组arr
进行冒泡排序。 -
外层
for
循环:for (int i = 0; i < arr.length; i++)
,循环执行arr.length
次,表示排序过程需要进行多次(每一轮都会将当前最大的元素"冒泡"到数组末尾)。 -
内层
for
循环:for (int j = 1; j < arr.length; j++)
,用于比较相邻的元素。如果前一个元素大于后一个元素,就交换它们的位置。
但是这个冒泡排序相对来说排序性能较低,在java内置中有更高效的排序算法
Array.sort
java
public static void main(String[] args){
int[] arr = {9,5,2,7};
Arrays.sort(arr);
System.out.println(Arrays.toString(arr));}