zoukankan      html  css  js  c++  java
  • 704. 二分查找

    题目:https://leetcode-cn.com/problems/binary-search/

    自己的代码:

    JAVA:
        public int search(int[] nums, int target) {
            int left = 0, right = nums.length - 1;
            while (left <= right){
                int mid = (left + right) / 2;//我的这种写法不多,因为left和right相加的结果可能会造成溢出
                if (nums[mid] == target) return mid;
                else if (nums[mid] > target) right = --mid;
                else if (nums[mid] < target) left = ++mid;
            }
            return -1;
        }

    官方:https://leetcode-cn.com/problems/binary-search/solution/er-fen-cha-zhao-by-leetcode-solution-f0xw/

    方法一:二分查找
    在升序数组nums 中寻找目标值target,对于特定下标 i,比较 nums[i] 和 target 的大小:

    • 如果nums[i]=target,则下标 i 即为要寻找的下标;
    • 如果 nums[i]>target,则 target 只可能在下标 i 的左侧;
    • 如果 nums[i]<target,则 target 只可能在下标 i 的右侧。

    基于上述事实,可以在有序数组中使用二分查找寻找目标值。
    二分查找的做法是,定义查找的范围[left,right],初始查找范围是整个数组。每次取查找范围的中点 mid,比较 nums[mid] 和 target 的大小,如果相等则 mid 即为要寻找的下标,如果不相等则根据 nums[mid] 和 target 的大小关系将查找范围缩小一半。
    由于每次查找都会将查找范围缩小一半,因此二分查找的时间复杂度是 O(logn),其中 n 是数组的长度。
    二分查找的条件是查找范围不为空,即left≤right。如果target 在数组中,二分查找可以保证找到 target,返回target 在数组中的下标。如果 target 不在数组中,则当 left>right 时结束查找,返回 -1。

    JAVA
    public int search(int[] nums, int target) {
            int low = 0, high = nums.length - 1;
            while (low <= high) {
                int mid = (high - low) / 2 + low;
                int num = nums[mid];
                if (num == target) {
                    return mid;
                } else if (num > target) {
                    high = mid - 1;
                } else {
                    low = mid + 1;
                }
            }
            return -1;
        }

    以下是C++:

  • 相关阅读:
    [Linux] expect命令 (自动交互脚本)
    [MAC] 终端bash_profile配置不生效问题
    [IDEA] 开发常用插件
    [MAC] 环境常用工具
    [IDEA] 快捷键输出固定代码模板
    家庭网络-多无线路由器实现无缝漫游
    家庭网络-AP组网方案(POE供电)
    家庭网络-软路由搭建方案
    队列使用
    [多线程] 线程池的使用
  • 原文地址:https://www.cnblogs.com/wltree/p/15377127.html
Copyright © 2011-2022 走看看