Java排序四:二分插入排序

来源:互联网 发布:唢呐软件下载 编辑:程序博客网 时间:2024/05/16 14:15
public class TestDemo {public static void main(String[] args) {int[] arr = new int[10];Random random = new Random();for (int i = 0; i < arr.length; i++) {arr[i] = random.nextInt(100);}display(arr);sort(arr);display(arr);}public static void sort(int[] arr) {int len = arr.length;int left, right, num;for (int i = 1; i < len; i++) {left = 0;right = i - 1;num = arr[i];while (left <= right) {int middle = (left + right) >> 0x1;if (num < arr[middle]) {right = middle - 1;} else {left = middle + 1;}}for (int j = i - 1; j >= left; j--) {arr[j + 1] = arr[j];}arr[left] = num;}}private static void swap(int[] arr, int i, int j) {if (i == j) {return;}arr[i] = arr[i] ^ arr[j];arr[j] = arr[i] ^ arr[j];arr[i] = arr[i] ^ arr[j];}private static void display(int[] arr) {for (int i = 0, len = arr.length; i < len; i++) {System.out.print(arr[i] + "  ");}System.out.println();}}

0 0
原创粉丝点击