二分查找
package Java.DataStructuresAndAlgorithms.Algorithms.search;
import java.util.ArrayList;
// import java.util.Scanner;
import java.util.List;
//韩门说这个二分查找这个条件一定要是有序的
//但是我感觉有序无序都是可以的
//事实上是不可以的
//
//这个二分查找是还可以去优化的
//我们用差值查找算法就可以让这个算法在某一情况下变得更加的简单
//查找的次数会变得更少一些
public class BinarySearch {
public static void main(String[] args) {
// Scanner scanner = new Scanner(System.in);
int arr[] = { 1, 8, 10, 89, 1000, 1000, 1000, 1000, 1234 };
// System.out.println("请您输入一个数字进行一个查找");
// int number = scanner.nextInt();
// int resIndex = binarySearch(arr, 0, arr.length - 1, number);
// // 这里我们要去考虑这个在里面不存在的值的时候,我们不考虑这个的时候,我们就不会去出现递归的出口,出现死递归
// if (resIndex == -1) {
// System.out.println("这个数是不存在这个数组当中的");
// }
// System.out.println("您所查找的数字的位置是:" + resIndex);
// scanner.close();
List<Integer> resIndexList = binarySearch2(arr, 0, arr.length - 1, 1000);
System.out.println(resIndexList);
}
// 二分查找
/**
*
* @param arr 数组
* @param left 左边的索引
* @param right 右边的索引
* @param findVal 要查找的值
* @return 如果找到了那么就去返回下标,没有找到的话就去返回-1
*/
public static int binarySearch(int[] arr, int left, int right, int findVal) {
if (left > right) {
return -1;
}
int mid = (left + right) / 2;
int minVal = arr[mid];
if (findVal > minVal) {
// 向右递归
return binarySearch(arr, mid + 1, right, findVal);
} else if (findVal < minVal) {
return binarySearch(arr, left, mid - 1, findVal);
} else {
return mid;
}
}
// 完成一个课后的思考题
// 当我们找到这个mid的时候一定先不要去返回
// 这时候我们可以先向这个mid索引值的左边进行一个扫描
// 将我们所需要的下边的计数添加到这个ArrayList这个集合
// mid的索引值的右边也是要这么去做
// 最后将这个ArrayList去返回
public static ArrayList<Integer> binarySearch2(int[] arr, int left, int right, int findVal) {
if (left > right) {
return new ArrayList<Integer>();
}
int mid = (left + right) / 2;
int minVal = arr[mid];
if (findVal > minVal) {
// 向右递归
return binarySearch2(arr, mid + 1, right, findVal);
} else if (findVal < minVal) {
return binarySearch2(arr, left, mid - 1, findVal);
} else {
ArrayList<Integer> resIndexList = new ArrayList<Integer>();
// return mid;
int temp = mid - 1;
while (true) {
if (temp < 0 || arr[temp] != findVal) {
break;
}
resIndexList.add(temp);
temp -= 1;
}
resIndexList.add(mid);
temp = mid + 1;
while (true) {
if (temp > arr.length - 1 || arr[temp] != findVal) {
break;
}
resIndexList.add(temp);
temp += 1;
}
return resIndexList;
}
}
}
斐波那契查找
package Java.DataStructuresAndAlgorithms.Algorithms.search;
import java.util.Arrays;
public class FibonacciSearch {
public static int maxSize = 20;
public static void main(String[] args) {
int[] arr = { 1, 8, 10, 89, 1000, 1234 };
System.out.println("index="+fibSearch(arr, 1234));
}
public static int[] fib() {
int[] f = new int[maxSize];
f[0] = 1;
f[1] = 1;
for (int i = 2; i < maxSize; i++) {
f[i] = f[i - 1] + f[i - 2];
}
return f;
}
public static int fibSearch(int[] a, int key) {
int low = 0;
int high = a.length - 1;
int k = 0;
int mid = 0;
int f[] = fib();
while (high > f[k] - 1) {
k++;
}
int[] temp = Arrays.copyOf(a, f[k]);
for (int i = high + 1; i < temp.length; i++) {
temp[i] = a[high];
}
while (low <= high) {
mid = low + f[k - 1] - 1;
if (key < temp[mid]) {
high = mid - 1;
k--;
} else if (key > temp[mid]) {
low = mid + 1;
k -= 2;
} else {
if (mid <= high) {
return mid;
} else {
return high;
}
}
}
return -1;
}
}
插值查找
package Java.DataStructuresAndAlgorithms.Algorithms.search;
// import java.util.Arrays;
public class InsertValueSearch {
public static void main(String[] args) {
int[] arr = new int[100];
for (int i = 0; i < 100; i++) {
arr[i] = i + 1;
}
int index = insertValueSearch(arr, 0, arr.length - 1, 100);
System.out.println(index);
// System.out.println(Arrays.toString(arr));
}
/**
* 这个算法也需要我们的数组是有序的
* @param arr
* @param left
* @param right
* @param findVal
* @return 如果找到就返回下标,找不到就是-1
*/
// 编写一个插值算法
public static int insertValueSearch(int[] arr, int left, int right, int findVal) {
System.out.println("查找次数~~~");
//这个判断是防止越界的
//是一定需要的
if (left > right || findVal < arr[0] || findVal > arr[arr.length - 1]) {
return -1;
}
//求出这个mid
int mid = left + (right - left) * (findVal - arr[left]) / (arr[right] - arr[left]);
int midVal = arr[mid];
if (findVal>midVal) {
return insertValueSearch(arr, mid + 1, right, findVal);
}else if (findVal<midVal) {
return insertValueSearch(arr, left, mid-1, findVal);
} else {
return mid;
}
}
}
线性查找
package Java.DataStructuresAndAlgorithms.Algorithms.search;
public class SeqSearch {
public static void main(String[] args) {
int arr[] = { 1, 9, 11, -1, 34, 89 };
// /找到一个就去返回
int index = seqSearch(arr, 11);
if (index==-1) {
System.out.println("no search");
} else {
System.out.println("the position: "+index);
}
}
public static int seqSearch(int[] arr, int value) {
for (int i = 0; i < arr.length; i++) {
if (arr[i] == value) {
return i;
}
}
return -1;
}
}