黑马程序员技术交流社区
标题:
想要将一个元素插入到该数组中,还要保证该数组是有序的
[打印本页]
作者:
lockwood
时间:
2015-5-2 23:01
标题:
想要将一个元素插入到该数组中,还要保证该数组是有序的
练习2:有一个有序 的数组,想要将一个元素插入到该数组中,还要保证该数组是有序的。
{1, 7, 3, 7, 3, 9, 3, 55, 22, 43} 例如将8 放入下列数组中,并且放入后,该数组还是有序的。
*/
class halfSearch {
public static void main(String[] args) {
int[] arr = {1, 7, 3, 7, 3, 9, 3, 55, 22, 43};
int index = halfSearch_2(arr,9);
System.out.println("index=" + index);
}
public static int halfSearch(int[] arr, int key) {
int min, max, mid;
min = 0;
max = arr.length - 1;
mid = (max + min) / 2;
while(arr[mid] != key) {
if(key > arr[mid]) {
min = mid + 1;
}
else if(key < arr[mid]){
max = mid - 1;
}
if(min > max) {
return -1;
}
mid = (max + min) / 2;
}
return mid;
}
//折半的另外一种思考方式,用折半不等于key 的方式来完成,如下,只要min《=max就能折半。
public static int halfSearch_2(int[] arr, int key) {
int min = 0, max = arr.length - 1, mid;
while (min <= max) {
mid = (max + min) >> 1;
if (key > arr[mid]) {
min = mid + 1;
}
else if (key < arr[mid]) {
max = mid - 1;
}
else {
return mid;
}
}
return -1;
}
/插入一个数并且保证依然是有序的
public static int halfSearch_3(int[] arr, int key) {
int min = 0, max = arr.length - 1, mid;
while (min <= max) {
mid = (max + min) >> 1;
if (key > arr[mid]) {
min = mid + 1;
}
else if (key < arr[mid]) {
max = mid - 1;
}
else {
return mid;
}
作者:
大西洋
时间:
2015-5-3 00:25
貌似用Set集合的TreeSet可以有序存放~ :)
作者:
下一页5
时间:
2015-5-3 00:27
我只记得-1改成min
作者:
lockwood
时间:
2015-5-3 07:48
大西洋 发表于 2015-5-3 00:25
貌似用Set集合的TreeSet可以有序存放~
还没学set集合哟~~~亲
作者:
lockwood
时间:
2015-5-3 07:51
下一页5 发表于 2015-5-3 00:27
我只记得-1改成min
索嘎!!带斯奈
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2