本文将在此公众号上通过一个个 ![]() ![]() ![]() ![]() ![]() ![]() ![]() int temp = 0; // 用来交换的临时数 // 要遍历的次数 for (int i = 0; i < list.length - 1; i++) { // 从后向前依次的比较相邻两个数的大小,遍历一次后,把数组中第i小的数放在第i个位置上 for (int j = list.length - 1; j > i; j--) { // 比较相邻的元素,如果前面的数大于后面的数,则交换 if (list[j - 1] > list[j]) { temp = list[j - 1]; list[j - 1] = list[j]; list[j] = temp; } } System.out.format('第 %d 趟: ', i); printAll(list); } } ![]() ![]() ![]() public void bubbleSort_2(int[] list) { int temp = 0; // 用来交换的临时数 boolean bChange = false; // 交换标志 // 要遍历的次数 for (int i = 0; i < list.length - 1; i++) { bChange = false; // 从后向前依次的比较相邻两个数的大小,遍历一次后,把数组中第i小的数放在第i个位置上 for (int j = list.length - 1; j > i; j--) { // 比较相邻的元素,如果前面的数大于后面的数,则交换 if (list[j - 1] > list[j]) { temp = list[j - 1]; list[j - 1] = list[j]; list[j] = temp; bChange = true; } } // 如果标志为false,说明本轮遍历没有交换,已经是有序数列,可以结束排序 if (false == bChange) break; System.out.format('第 %d 趟: ', i); printAll(list); } } ![]() ![]() ![]() ![]() ![]() ![]() ![]() ![]() ———— 编辑 ∑Gemini 来源:视学算法 |
|