展开全部
这样的代码看的费劲
数组排序62616964757a686964616fe59b9ee7ad9431333363366165的方法有冒泡和选择比较的好理解:
代码如下:
package com.tx.wl.p10;
public class ArrayDemo {
public static void main(String[] args) {
int[] a = { 3, 43, 22, 4, 22, 31, 23 };
System.out.println("遍历数组:");
showArray(a);
System.out.println("冒泡排序:");
maoPao(a);
showArray(a);
System.out.println("选择排序:");
xuanze(a);
showArray(a);
}
private static void xuanze(int[] a) {
int[] b = a;
for (int i = 0; i < b.length; i++) {
int index = i;
for (int j = i; j < b.length; j++) {
if (a[index] > b[j]) {
index = j;
}
}
int temp = b[index];
b[index] = b[i];
b[i] = temp;
}
}
private static void maoPao(int[] a) {
int[] c = a;
for (int i = 0; i < c.length; i++) {
for (int j = 0; j < c.length - i - 1; j++) {
if (c[j] > c[j + 1]) {
int temp = c[j];
c[j] = c[j + 1];
c[j + 1] = temp;
}
}
}
}
private static void showArray(int[] a) {
for (int aa : a) {
System.out.print(aa + " ");
}
System.out.println();
}
}
理解型记忆,里面的遍历用的是增强for,原理就相当于
for(int i=0; i
System.ou.tprintln(a[i]);
}