Java对数组元素升序排序
1 说明
在此程序中,我们需要按升序对给定的数组进行排序,以便将元素从最小到最大排列。这可以通过两个循环来实现。外循环将选择一个元素,而内循环则允许我们将所选元素与其余元素进行比较。
元素的排序方式是最小元素将出现在最左端,在这种情况下为1。最大元素将出现在最右端,在这种情况下为8。
2 算法思路
- 步骤1:开始
- 步骤2:初始化arr [] = {5、2、8、7、1}。
- 步骤3: SET TEMP = 0
- 步骤4:打印“Elements of Original Array”
- 步骤5:重复步骤6直到i <arr.length
// for(i = 0; i <arr.length; i ++) - 步骤6:列印arr [i]
- 步骤7:将步骤8重复到步骤9直到i <arr.length
// for(i = 0; i <arr.length; i ++) - 步骤8: 重复步骤9直到j <arr.length
//for(j=i+1;j<arr.length;j++) - 步骤9: if(arr [i]> arr [j])则
temp = arr [i]
arr [i] = arr [j]
arr [j] = temp - 第10步:打印新行
- 步骤11:打印“Elements of array sorted in ascending order”
- 步骤12:重复步骤13直到i <arr.length
//for(i=0;i<arr.length;i++) - 步骤13:列印arr [i]
- 步骤14:结束
3 程序实现
/**
* 一点教程网: http://www.yiidian.com
*/
public class SortAsc {
public static void main(String[] args) {
//Initialize array
int [] arr = new int [] {5, 2, 8, 7, 1};
int temp = 0;
//Displaying elements of original array
System.out.println("Elements of original array: ");
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
//Sort the array in ascending order
for (int i = 0; i < arr.length; i++) {
for (int j = i+1; j < arr.length; j++) {
if(arr[i] > arr[j]) {
temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
System.out.println();
//Displaying elements of array after sorting
System.out.println("Elements of array sorted in ascending order: ");
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
}
}
以上代码输出结果为:
Elements of original array:
5 2 8 7 1
Elements of array sorted in ascending order:
1 2 5 7 8
热门文章
优秀文章