LeeCode数组问题:二分查找
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数组问题:二分查找的更多相关文章
- PHP-----二维数组和二分查找
二维数组由行和列组成.由arr[$i][$j]表示,先后表示行和列,类似于坐标点. 打印二维数组-----通过两次遍历,第一次遍历每一行,第二次遍历每一行的具体元素,并且通过使用count($arr[ ...
- java 13-1 数组高级二分查找
查找: 1.基本查找:数组元素无序(从头找到尾) 2.二分查找(折半查找):数组元素有序 pS:数组的元素必须有顺序,从小到大或者从大到小.以下的分析是从小到大的数组 二分查找分析: A:先对数组进行 ...
- Java数据结构和算法总结-数组、二分查找
前言:在平时开发中数组几乎是最基本也是最常用的数据类型,相比链表.二叉树等又简单很多,所以在学习数据和算法时用数组来作为一个起点再合适不过了.本篇博文的所有代码已上传 github ,对应工程的 ar ...
- [c/c++] programming之路(15)、多维数组和二分查找法,小外挂
一.多维数组 #include<stdio.h> #include<stdlib.h> void main(){ ][]; int i,j; ; i < ; i++) { ...
- [算法][LeetCode]Search a 2D Matrix——二维数组的二分查找
题目要求 Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the ...
- [19/03/13-星期三] 数组_二维数组&冒泡排序&二分查找
一.二维数组 多维数组可以看成以数组为元素的数组.可以有二维.三维.甚至更多维数组,但是实际开发中用的非常少.最多到二维数组(我们一般使用容器代替,二维数组用的都很少). [代码示例] import ...
- 【大视野入门OJ】1083:数组的二分查找
Description 在1500个整数中查整数x的位置,这些数已经从小到大排序了.若存在则输出其位置,若不存在则输出-1. Input 第一行,一个整数x 后面1500行,每行一个整数 Output ...
- Java数组之二分查找
简单的二分查找 package com.kangkang.array; public class demo03 { public static void main(String[] args) { / ...
- leetcode:Search for a Range(数组,二分查找)
Given a sorted array of integers, find the starting and ending position of a given target value. You ...
- 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 ...
随机推荐
- Python爬虫之Scrapy制作爬虫
前几天我有用过Scrapy架构编写了一篇爬虫的代码案例深受各位朋友们喜欢,今天趁着热乎在上一篇有关Scrapy制作的爬虫代码,相信有些基础的程序员应该能看的懂,很简单,废话不多说一起来看看. 前期准备 ...
- VUE keepAlive缓存问题之动态使用exclude(会使用到VUEX)
exclude是啥? 官方解释: 怎么用呢? 处理的问题是什么?(答:返回首页的时候清除B页面的缓存) 我遇到的问题是: 一开始状态:A(首页). B(列表).C(列表中的详情)三个页面,设置B页面的 ...
- doy 20 系统优化
系统优化 1.yum源的优化 CentOS base epel 自建yum仓库使用一个较为稳定的仓库wget -O /etc/yum.repos.d/CentOS-Base.repo h ...
- 实验一Linux系统与应用准备
实验一Linux系统与应用准备 |这个作业属于哪个课程|内容| | ---- | ---- | ---- | |这个作业属于哪个课程|2021春季Linux系统与应用 (南昌航空大学 - 信息工程学院 ...
- jsp第4个作业(1)
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"% ...
- Longest Common Substring(最长公共子串)
SP1811 题目描述 A string is finite sequence of characters over a non-empty finite set Σ. In this problem ...
- hi,docker,docker的介绍
一.docker的介绍 1.什么是docker: docker是一种虚拟化技术,小型的系统环境(linux)2.虚拟化技术: 在计算机中用例管理虚拟资源的一种手段 内存管理.软件虚拟化.硬件虚拟化(磁 ...
- sql server数据库的带返回值的存储和函数的基础使用
准备基本的数据 create table test_table ( id int identity(0,1), name varchar(20), age int, book_name varchar ...
- var 和let const的区别
var 是ES5语法,let,const是ES6语法,var存在变量提升. let const有块级作用域,var没有
- PHP文件及运行(适合PHP初学者)
PHP文件可包含HTML.JavaScript代码和 PHP代码,换句话说PHP 代码可以嵌入HTML文档.PHP文件名以php为后缀. PHP代码以"<?php"开头,以& ...