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 ...
随机推荐
- 二,使用axios
1,下载https://unpkg.com/axios@1.3.2/dist/axios.min.js保存在js目录下,命名为axios.js 2,http.js let baseUrl = &quo ...
- CSS面试题及答案
介绍一下标准的CSS的盒子模型?与低版本IE的盒子模型有什么不同的? 标准盒子模型:宽度=内容的宽度(content)+ border + padding + margin 低版本IE盒子模型:宽度= ...
- 字符节点流--> 桥装换流
输出 存值 用法1创建字节输出节点流FileOutputStream fos = new FileOutputStream("存入文件的路径");2创建桥转换流,按照指定的字符编码 ...
- C#发送字符串转字节含空格与0x需删去
主要作用:清除发送字符串转字节中的空格和16进制前缀0x, 字节转换按两位字符转换为一个字节,多余一位按一位字符转换一个字节 //清除空格和16进制前缀发送 String sendstr;// = n ...
- Java的流程控制
Scanner对象 next(); 一定要读取到有效字符后才可以结束输入. 对输入有效字符之前遇到的空白,next()方法会自动将其去掉(). 只有输入有效字符后才将其后面输入的空白作为分隔符或者结束 ...
- Zookeeper分布式服务
Zookeeper(CP) 以集群的方式[leader和follower]为分布式应用提供协调服务.负责存储和管理大家都关系的数据,接受观察者注册.消息分发等服务 特点: 只要有半数以上的节点存活就能 ...
- 关于 indy Idhttp Post数据抛异常 connection closed Gracefully
delphi 使用indy -idHttp 控件post 数据时 会报connection closed Gracefully这个异常的问题. 网上找了很多方法最多的就是 修改: MyHttp.Req ...
- Code UTF-8 Console GB2312 Linux 中文乱码
Linux 系统方法: LD_LIBRARY_PATH=. ./userdemo | iconv -f GB2312 -t utf8 Shell 方法 Shell 编码 改成GB2312 // 编 ...
- C 系列的暂停
由于Mooc上有关C 的课程并不是很全面,网络上有关于C 的消息过于杂糅,所以暂时停止C的学习,重启时间暂定,等什么时候需要的时候再做重启.
- 【前端工程化】使用Nexus 搭建前端 npm 私服
参考文献1 - https://blog.51cto.com/lookingdream/3609619 参考文献2 - https://blog.csdn.net/u013278374/article ...