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. Python爬虫之Scrapy制作爬虫

    前几天我有用过Scrapy架构编写了一篇爬虫的代码案例深受各位朋友们喜欢,今天趁着热乎在上一篇有关Scrapy制作的爬虫代码,相信有些基础的程序员应该能看的懂,很简单,废话不多说一起来看看. 前期准备 ...

  2. VUE keepAlive缓存问题之动态使用exclude(会使用到VUEX)

    exclude是啥? 官方解释: 怎么用呢? 处理的问题是什么?(答:返回首页的时候清除B页面的缓存) 我遇到的问题是: 一开始状态:A(首页). B(列表).C(列表中的详情)三个页面,设置B页面的 ...

  3. doy 20 系统优化

    系统优化 1.yum源的优化 CentOS   base   epel ​自建yum仓库​使用一个较为稳定的仓库​wget -O /etc/yum.repos.d/CentOS-Base.repo h ...

  4. 实验一Linux系统与应用准备

    实验一Linux系统与应用准备 |这个作业属于哪个课程|内容| | ---- | ---- | ---- | |这个作业属于哪个课程|2021春季Linux系统与应用 (南昌航空大学 - 信息工程学院 ...

  5. jsp第4个作业(1)

    <%@ page language="java" import="java.util.*" pageEncoding="utf-8"% ...

  6. Longest Common Substring(最长公共子串)

    SP1811 题目描述 A string is finite sequence of characters over a non-empty finite set Σ. In this problem ...

  7. hi,docker,docker的介绍

    一.docker的介绍 1.什么是docker: docker是一种虚拟化技术,小型的系统环境(linux)2.虚拟化技术: 在计算机中用例管理虚拟资源的一种手段 内存管理.软件虚拟化.硬件虚拟化(磁 ...

  8. sql server数据库的带返回值的存储和函数的基础使用

    准备基本的数据 create table test_table ( id int identity(0,1), name varchar(20), age int, book_name varchar ...

  9. var 和let const的区别

    var 是ES5语法,let,const是ES6语法,var存在变量提升. let const有块级作用域,var没有

  10. PHP文件及运行(适合PHP初学者)

    PHP文件可包含HTML.JavaScript代码和 PHP代码,换句话说PHP 代码可以嵌入HTML文档.PHP文件名以php为后缀. PHP代码以"<?php"开头,以& ...