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. Redis各个客户端的对比

    [Spring RedisTemplate 的底层一开始使用Jedis.但是自从SpringBoot2开始,底层开始使用了Lettuce,故不算在内] [题外话:如果要使用Spring来集成对Redi ...

  2. React中的CSS模块

    CSS模块       使用步骤:         1.新建一个XXX.moudle.css文件         2.在组件中引入css           impor classes(变量) fro ...

  3. Nginx系列---【配置文件中静态资源文件禁止通过目录查看】

    配置文件中静态资源文件禁止通过目录查看 1.问题 nginx作为文件服务器时,默认是可以通过目录路径查看该目录下的所有文件的,这样很不安全,容易造成静态资源泄露. 2.方案 location /ima ...

  4. api接口文档生成,无需其他配置一键生成基于文本注释

    <dependency> <groupId>io.github.yedaxia</groupId> <artifactId>japidocs</a ...

  5. 【Unity】阅读LuaFramework_UGUI的一种方法

    写在前面 我第一次接触到LuaFramework_UGUI是在一个工作项目中,当时也是第一次知道toLua.但我刚开始了解LuaFramework_UGUI时十分混乱,甚至将LuaFramework_ ...

  6. Ubuntu VMWare安装纪要

    一.VMware虚拟机下载与安装 版本:VMware Workstation 16 Pro 二.Ubuntu下载与安装 版本:ubuntu-20.04.2.0-desktop-amd64.iso 三. ...

  7. java相关部分配置

    一.mybatis逆向工程 ① generator.properties jdbc.driverLocation=D:/testDir/Maven/repository_g/mysql/mysql-c ...

  8. idea修改背景颜色|护眼色|项目栏背景修改

    https://blog.csdn.net/heytyrell/article/details/89743068

  9. 115、商城业务---分布式事务---使用Springboot提供的Seata解决分布式事务

    https://seata.io/zh-cn/ seata使用Seata AT模式控制分布式事务的步骤: 1.每一个想控制分布式事务的服务对应的数据库都需要创建一个UNDO_LOG 表 CREATE ...

  10. NXOpen遍历工作部件表达式

    //用户代码#include <uf_defs.h>#include <NXOpen/NXException.hxx>#include <NXOpen/Session.h ...