题目:用java实现数组快速排序功能
首先要实现快速排序的话需要先得到数组里的每一个数字,先遍历这个数组,即:
第一步
int[] arr = {2,1,5,4,7,9};
for (int i = 0; i < arr.length; i++) {
{
此时,我们就拿到了所有的一维数组里面的数据,要想整个都排序的话需要将所有的元素都拿出来比较一下所以for循环里面需要再嵌套一个for循环,起到使所有元素都拿出来比较的效果,又因为最后一个元素最终的时候不需要拿出来比较了,已经可以了所以第一步中的for循环可以简单改变一下,最终出来的结果为:
第二步(这里稍微改变了一下第一步for循环)
for (int i = 0; i < arr.length-1; i++) {
for (int j = 0; j < arr.length-1-i; j++) {
}
}
此时就需要加入判断语句判断一下元素的大小进行排序了,我们在内层for循环里面加入判断语句,即:
第三步
if (arr[j] > arr[j + 1]) {
int a = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = a;
}
这样就实现了排序,最终添加些好看的修饰语句,最终代码为:
最终代码
public class Demo2 {
public static void main(String[] args) {
int[] arr = {2,1,5,4,7,9};
for (int i = 0; i < arr.length-1; i++) {
for (int j = 0; j < arr.length-1-i; j++) {
if (arr[j] > arr[j + 1]) {
int a = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = a;
}
}
}
System.out.println(Arrays.toString(arr));
}
}
控制台打印结果:
[1, 2, 4, 5, 7, 9]