LeeCode 704 二分查找

题目描述:

给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1

标签: 数组、二分查找

建立模型:

该题为一个简单的二分查找实现,注意边界处理即可。

编码实现

/* Java实现 */
class Solution {
public int search(int[] nums, int target) {
if (nums.length == 0 || target < nums[0] || target > nums[nums.length - 1]) {
return -1;
} int low = 0, high = nums.length - 1;
while (low <= high) {
int mid = low + (high - low) / 2;
if (nums[mid] < target) {
low = mid + 1;
}
else if (nums[mid] > target) {
high = mid - 1;
}
else {
return mid;
}
} return -1; //未搜索到则不存在返回-1
}
}
# Python实现
class Solution:
def search(self, nums: List[int], target: int) -> int:
if len(nums) == 0 or target < nums[0] or target > nums[len(nums) - 1]:
return -1
low, high = 0, len(nums) - 1 while low <= high:
mid = low + (high - low) // 2
if nums[mid] < target:
low = mid + 1
elif nums[mid] > target:
high = mid - 1
else:
return mid
return -1

LeeCode 35 插入搜索位置

题目描述:

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。

标签:数组、二分查找

建立模型:

该题也是一个简单二分查找模型,只是对返回值稍做变化。

编码实现

/* Java实现 */
class Solution {
public int searchInsert(int[] nums, int target) {
if (nums.length == 0 || target < nums[0]) {
return 0;
} if (target > nums[nums.length - 1]) {
return nums.length;
} int low = 0, high = nums.length - 1;
while (low <= high) {
int mid = low + (high - low) / 2;
if (nums[mid] < target) {
low = mid + 1;
}
else if (nums[mid] > target) {
high = mid - 1;
}
else {
return mid;
}
} return low;
}
}
# Python实现
class Solution:
def searchInsert(self, nums: List[int], target: int) -> int:
if not nums or target < nums[0]:
return 0
if target > nums[len(nums) - 1]:
return len(nums) low, high = 0, len(nums) - 1 while low <= high:
mid = low + (high - low) // 2
if nums[mid] < target:
low = mid + 1
elif nums[mid] > target:
high = mid - 1
else:
return mid
return low

LeeCode 34 查找元素的第一个和最后一个位置

题目描述:

给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。如果数组中不存在目标值 target,返回 [-1, -1]

标签:数组、二分查找

建立模型:

  • 与其他二分查找的不同之处在目标值可能存在多个,单纯的二分查找无法确定目标值的位置。
  • 在执行binarySearchLast时,需注意对mid的变化。

编码实现

/* Java实现 */
class Solution {
public int[] searchRange(int[] nums, int target) {
if (nums.length == 0 || target < nums[0] or target > nums[nums.length - 1]) {
return new int[] {-1, -1};
}
return new int[]{binarySearchFirst(nums, target), binarySearchLast(nums, target)};
} public int binarySearchFirst(int[] nums, int target) {
int left = 0, right = nums.length - 1;
while (left < right) {
int mid = left + (right - left) / 2;
if (nums[mid] >= target) {
right = mid;
}
else {
left = mid + 1;
}
} if (nums[left] == target) {
return left;
}
return -1;
} public int binarySearchLast(int[] nums, int target) {
int left = 0, right = nums.length - 1;
while (left < right) {
int mid = left + (right - left + 1) / 2; // +1实现mid的右移, 避免进入死循环
if (nums[mid] <= target) {
left = mid;
}
else {
right = mid - 1;
}
} if (nums[left] == target) {
return left;
}
return -1;
}
}
# Python实现
class Solution:
def searchRange(self, nums: List[int], target: int) -> List[int]:
if target < nums[0] or target > nums[len(nums) - 1]:
return [-1, -1]
return [self.binarySearchFirst(nums, target), self.binarySearchLast(nums, target)] def binarySearchFirst(self, nums: List[int], target: int) -> int:
low, high = 0, len(nums) - 1
while low < high:
mid = low + (high - low) // 2 # 在偶数个数时取左边的为mid
if nums[mid] >= target:
high = mid
else:
low = mid + 1
return low if nums[low] == target else -1 def binarySearchLast(self, nums: List[int], target: int) -> int:
low, high = 0, len(nums) - 1
while low < high:
mid = low + (high - low + 1) // 2 # 在偶数个数时取右边的为mid
if nums[mid] <= target:
low = mid
else:
high = mid - 1
return low if nums[low] == target else -1

LeeCode数组问题:二分查找的更多相关文章

  1. PHP-----二维数组和二分查找

    二维数组由行和列组成.由arr[$i][$j]表示,先后表示行和列,类似于坐标点. 打印二维数组-----通过两次遍历,第一次遍历每一行,第二次遍历每一行的具体元素,并且通过使用count($arr[ ...

  2. java 13-1 数组高级二分查找

    查找: 1.基本查找:数组元素无序(从头找到尾) 2.二分查找(折半查找):数组元素有序 pS:数组的元素必须有顺序,从小到大或者从大到小.以下的分析是从小到大的数组 二分查找分析: A:先对数组进行 ...

  3. Java数据结构和算法总结-数组、二分查找

    前言:在平时开发中数组几乎是最基本也是最常用的数据类型,相比链表.二叉树等又简单很多,所以在学习数据和算法时用数组来作为一个起点再合适不过了.本篇博文的所有代码已上传 github ,对应工程的 ar ...

  4. [c/c++] programming之路(15)、多维数组和二分查找法,小外挂

    一.多维数组 #include<stdio.h> #include<stdlib.h> void main(){ ][]; int i,j; ; i < ; i++) { ...

  5. [算法][LeetCode]Search a 2D Matrix——二维数组的二分查找

    题目要求 Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the ...

  6. [19/03/13-星期三] 数组_二维数组&冒泡排序&二分查找

    一.二维数组 多维数组可以看成以数组为元素的数组.可以有二维.三维.甚至更多维数组,但是实际开发中用的非常少.最多到二维数组(我们一般使用容器代替,二维数组用的都很少). [代码示例] import ...

  7. 【大视野入门OJ】1083:数组的二分查找

    Description 在1500个整数中查整数x的位置,这些数已经从小到大排序了.若存在则输出其位置,若不存在则输出-1. Input 第一行,一个整数x 后面1500行,每行一个整数 Output ...

  8. Java数组之二分查找

    简单的二分查找 package com.kangkang.array; public class demo03 { public static void main(String[] args) { / ...

  9. leetcode:Search for a Range(数组,二分查找)

    Given a sorted array of integers, find the starting and ending position of a given target value. You ...

  10. leetcode:Search a 2D Matrix(数组,二分查找)

    Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...

随机推荐

  1. vue 数组对象去重

    unique(arr) {     const res = new Map();     return arr.filter((arr) => !res.has(arr.id) &&am ...

  2. 源代码管理工具介绍(以GITHUB为例)

    Github:全球最大的社交编程及代码托管网站,可以托管各种git库,并提供一个web界面 1.基本概念 仓库(Repository):用来存放项目代码,每个项目对应一个仓库,多个开源项目则有多个仓库 ...

  3. COM调用 – VB、PB

    本文使用Delphi和C++创建CRC32的COM文件(Dll). VB: V9.0 PB: V8.0 Delphi创建的文件,提供给VB9调用:C++创建的文件,提供给PB8调用. 一.VB部分 C ...

  4. junit单元测试踩过的坑

    1.测试方法不能直接获取到系统初始化的配置信息,需要专门读取 2.单元测试多线程子线程不执行,不会像主线程一样等待子线程退出而退出, 会直接退出. . https://blog.csdn.net/yu ...

  5. Git在使用过程中遇到的一些问题

    git默认对文件中的大小写不敏感. 方案1: 通过配置git来达到识别文件大小写的问题.命令如下: git config core.ignorcecase false 缺点:每个仓库都需要修改. 方案 ...

  6. C知识点

    1.变量在内存中所占存储空间的首地址,称为该变量的地址:而变量在存储空间中存放的数据,即变量的值. C语言中,指针就是变量的地址.一个变量的值是另一个变量的地址,且变量类型相同,则称该变量为指针变量. ...

  7. 关于office 16

    word是office的组件之一,Excel也是其中之一. 一用有八大组件.  

  8. 痞子衡嵌入式:内存读写正确性压力测试程序(memtester)

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是内存读写正确性压力测试程序memtester. 在嵌入式系统中,内存(RAM)的重要性不言而喻,系统性能及稳定性都与内存息息相关.关于内 ...

  9. 自己动手从零写桌面操作系统GrapeOS系列教程——13.向MBR中写入程序

    学习操作系统原理最好的方法是自己写一个简单的操作系统. 前面铺垫了这么久,今天终于开始写程序了.本讲将介绍3个逐步深入但非常简单的程序,一方面是让大家熟悉开发流程,另一方面是顺便解决前面遇到的CPU占 ...

  10. Flutter 2 渲染原理和如何实现视频渲染

    7 月 17 日下午,在前端专场巡回沙龙北京站中,声网Agora跨平台开发工程师卢旭辉带来了<Flutter2 渲染原理和如何实现视频渲染>的主题分享,本文是对演讲内容的整理. 本次分享主 ...