java常用查找算法
2022/4/6 17:19:56
本文主要是介绍java常用查找算法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
java常用查找算法
线性查找
/** * 找到一个就返回 * @param arr 数组 * @param value 需要找的数 * @return 找的数的下标,没找到为-1 */ public static int seqSearch(int[] arr, int value) { for (int i = 0; i < arr.length; i++) { if (arr[i] == value) { return i; } } return -1; }
二分查找
递归法(找一个)
/** * 二分查找一个值 * 必须left和right中间有序 * * @param arr 数组 * @param left 左边的索引 * @param right 右边的索引 * @param value 需要查找的值 * @return 值的下标,-1为找不到 */ public static int binary(int[] arr, int left, int right, int value) { if (left > right) { return -1; } int mid = left + (right - left) / 2; int midValue = arr[mid]; // 如果要找的值在右边 if (value > midValue) { // 向右递归 return binary(arr, mid + 1, right, value); } else if (value < midValue) { return binary(arr, left, mid - 1, value); } else { // 等于,返回 return mid; } }
递归法(找多个)
/** * 二分查找多个值 * 必须left和right中间有序 * * @param arr 数组 * @param left 左边的索引 * @param right 右边的索引 * @param value 需要查找的值 * @return 值的下标, null为找不到 */ public static List binary02(int[] arr, int left, int right, int value) { if (left > right) { return null; } int mid = left + (right - left) / 2; int midValue = arr[mid]; // 如果要找的值在右边 if (value > midValue) { // 向右递归 return binary02(arr, mid + 1, right, value); } else if (value < midValue) { return binary02(arr, left, mid - 1, value); } else { List<Integer> ans = new ArrayList<>(); int temp = mid - 1; // 向左扫描 while (true) { if (temp < 0 || arr[temp] != value) { break; } ans.add(temp--); } ans.add(mid); // 向右扫描 temp = mid + 1; while (true) { if (temp > arr.length - 1 || arr[temp] != value) { break; } ans.add(temp++); } return ans; } }
插值查找
public static int insert(int[] arr, int left, int right, int value) { if (left > right || value < arr[0] || value > arr[arr.length - 1]) { return -1; } int mid = left + (right - left) * ((value - arr[left]) / (arr[right] - arr[left])); int midValue = arr[mid]; if (value > midValue) { // 在mid的右边 return insert(arr, mid + 1, right, value); } else if (value < midValue) { // 在mid的左边 return insert(arr, left, mid - 1, value); } else { return mid; } }
斐波那契黄金分割法查找
// 得到斐波那契数列 public static int[] getFibonacci() { int max = 20; int[] f = new int[max]; f[0] = 1; f[1] = 1; for (int i = 2; i < max; i++) { f[i] = f[i - 1] + f[i - 2]; } return f; } public static int fibonacci(int[] arr, int value) { int low = 0; int high = arr.length - 1; // 获取到斐波那契数列分割数值的下标 int k = 0; int mid = 0; int[] f = getFibonacci(); // 拿到k while (high > f[k] - 1) { ++k; } // f[k]可能大于数组长度,扩容 int[] temp = Arrays.copyOf(arr, f[k]); // 需要使用arr数组中最后的数填充 for (int i = high + 1; i < temp.length; i++) { temp[i] = arr[high]; } // 处理拿到k while (low <= high) { // 拿到mid mid = low + f[k - 1] - 1; if (value < arr[mid]) { // 向左 high = mid - 1; --k; } else if (value > arr[mid]) { // 向右 low = mid + 1; k -= 2; } else { // 找到 if (mid <= high) { return mid; } else { return high; } } } return -1; }
这篇关于java常用查找算法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-04敏捷管理与看板工具:提升研发、设计、电商团队工作效率的利器
- 2025-01-04智慧养老管理工具如何重塑养老生态?
- 2025-01-04如何打造高绩效销售团队:工具与管理方法的结合
- 2025-01-04解决电商团队协作难题,在线文档工具助力高效沟通
- 2025-01-04春节超市管理工具:解锁高效运营与顾客满意度的双重密码
- 2025-01-046种主流销售预测模型:如何根据场景选用最佳方案
- 2025-01-04外贸服务透明化:增强客户信任与合作的最佳实践
- 2025-01-04重新定义电商团队协作:在线文档工具的战略作用
- 2025-01-04Easysearch Java SDK 2.0.x 使用指南(三)
- 2025-01-04百万架构师第八课:设计模式:设计模式容易混淆的几个对比|JavaGuide