赞
踩
选择排序:每一次找出数组中最小的元素,并放在对应的索引位置上。一般为两位for循环,内层for循环不断的缩减。不稳定,时间复杂度为 O(n²)
两层for循环
for (int i = 0; i < arr.length; i++) {
for (int j = i + 1; j < arr.length; j++) {}
}
/** * 作者:Hui */ /** * 选择排序:每一次找出数组中最小的元素,并放在对应的索引位置上。 * 一般为两位for循环,内层for循环不断的缩减。 * * @author: Hui **/ public class SeletionSort { public static void main(String[] args) { //初始化数组 int[] arr = {1, 5, 3, 456, 5, 6, 7, 13, 9, 100}; System.out.println("排序前:"); for (int i = 0; i < arr.length; i++) { System.out.println(arr[i]); } SeletionSort seletionSort = new SeletionSort(); seletionSort.seletionSortMethod(arr); System.out.println("排序后:"); for (int i = 0; i < arr.length; i++) { System.out.println(arr[i]); } } public int[] seletionSortMethod(int arr[]) { int min; for (int i = 0; i < arr.length; i++) { min = i; //插入的索引位置 for (int j = i + 1; j < arr.length; j++) { if (arr[j] < arr[min]) { //找到比当前值要小的就赋值 min = j; } } if (i != min) { //比较完之后继续赋值 int temp = arr[i]; arr[i] = arr[min]; arr[min] = temp; } } return arr; } }
我是小辉,24 届毕业生。当下是找工作ing,欢迎关注,持续分享。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。