您的位置:首页 > 编程语言 > Java开发

Java排序四:二分插入排序

2016-03-01 23:31 295 查看
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();
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: