二分查找非递归

曾经终败给现在 2021-10-16 00:54 476阅读 0赞
  1. package com.BinarySearchNoRecur;
  2. /**
  3. * @Auther: 大哥的叔
  4. * @Date: 2019/8/20 19:31
  5. * @Description:
  6. */
  7. public class BinarySearchNoRecur {
  8. public static void main(String[] args) {
  9. //测试
  10. int[] arr = {1,3, 8, 10, 11, 67, 100};
  11. int index = binarySearch(arr, 100);
  12. System.out.println("index=" + index);//
  13. }
  14. //二分查找的非递归实现
  15. /**
  16. * @param arr 待查找的数组, arr是升序排序
  17. * @param target 需要查找的数
  18. * @return 返回对应下标,-1表示没有找到
  19. */
  20. public static int binarySearch(int[] arr, int target) {
  21. int left = 0;
  22. int right = arr.length - 1;
  23. while(left <= right) { //说明继续查找
  24. int mid = (left + right) / 2;
  25. if(arr[mid] == target) {
  26. return mid;
  27. } else if ( arr[mid] > target) {
  28. right = mid - 1;//需要向左边查找
  29. } else {
  30. left = mid + 1; //需要向右边查找
  31. }
  32. }
  33. return -1;
  34. }
  35. }

发表评论

表情:
评论列表 (有 0 条评论,476人围观)

还没有评论,来说两句吧...

相关阅读