查找

二分查找

二分搜索,即在有序数组中,查找某一特定元素的搜索。它从中间的元素开始,如果中间的元素是要找的元素,则返回;若中间元素小于要找的元素,则要找的元素一定在大于中间元素的那一部分,那只需搜索那部分即可;反之搜索小于中间元素的部分即可。重复以上步骤,直到找到或确认该元素不存在为止。

func binarySearch(nums: [Int], target: Int) -> Bool {
    var left = 0, mid = 0, right = nums.count - 1
    
    while left <= right {
        mid = (right - left) / 2 + left
        let midNum = nums[mid]
        if midNum == target {
            return true
        } else if midNum < target {
            left = mid + 1
        } else {
            right = mid - 1
        }
    }
    
    return false
}

你可能感兴趣的:(查找)