一种效率较高的查找方法(效率最高的查找方法)

本文分享自华为云社区《》,作者: i进击的攻城狮 。

一、二分查找概述

二分查找是一种相比于逐个查找,性能更加优秀,时间复杂度更低的一种算法。

二分查找的思路是,对一个顺序的集合,确定查找区间的左右边界,再根据左右边界,计算出中间的值,再和中间值进行比较,如果左边界大于中间值,左边界向右移动到中间值+1的位置,反之右边界移动的中间值左边的位置。

示例一:
输入: nums = [-1,0,3,5,9,12], target = 9

一种效率较高的查找方法(效率最高的查找方法)

输出: 4
解释: 9 出现在 nums 中并且下标为 4

首先左边界left是0,右边界right是5,

mid中间值计算公式是:

**(右-左) / 2 + 左 **= (5-0)/2 + 0 = 2.5,向下取整为2。

这里要注意,一般二分查找中,mid中间下标计算结果是小数,都是向下取整。

nums[2] = 3;

3 小于目标 9,可以判断目标值在右区间。

左 = 中 + 1;

left改变后重新计算下标,计算中间下标值是:

(5-3)/2 +3 = 4;此时数[4] = 9;

找到目标值。

代码如下

class Solution {
public int search(int[] nums, int target) {
int l = 0;
int r = nums.length-1;
while (l<=r){
int m = (r-l)+l;
if (nums[m]==target){
return m;
}else if (target<nums[m]){ r="m-1;" }else="" {="" l="m+1;" }="" return="" -1;="" }

二、分查找解决算法问题

二分查找并不是只是简简单单的去判断一个数组中,是否存在目标值,它是一种解决问题的思想。二分查找能衍生出一些算法问题。接下来由如下三个模板,去了解如何用二分查找去解决问题。

2.1 模板I(标准模板)

int binarySearch(int[] nums, int target){
if(nums == null || nums.length == 0)
return -1;
int left = 0, right = nums.length - 1;
while(left <= right){
// Prevent (left + right) overflow
int mid = left + (right - left) / 2;
if(nums[mid] == target){ return mid; }
else if(nums[mid] < target) { left = mid + 1; }
else { right = mid - 1; }
}
// End Condition: left > right
return -1;
}

模板1是二分查找的最基础和最基本的形式。这是一个标准的二分查找模板,大多数高中或大学会在他们第一次教学生计算机科学时使用。模板 1 用于查找可以通过访问数组中的单个索引来确定的元素或条件。

在这个模板中,left和right会不断靠近,最后一次遍历的时候,两个值left和right会相等。

x 的平方根

给你一个非负整数 x ,计算并返回 x 的 算术平方根 。

由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。

注意:不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5 。

示例 1:
输入:x = 4
输出:2

思路

在从1到x中寻找x的平方根,如果mid的平方大于x,那么right = mid - 1 同理,反之就是left = mid + 1

代码:

public int mySqrt(int x) {
if (x==0){return 0;}
if (x==1){return 1;}
int l = 0;
int r = x;
while(l<=r){
int m = (r-l)/2+l;
if (x/m==m){
return m;
}else if(x/m<m){ 16="" 8="" m){
l = m + 1;
}
}
return r;
}

2.2 二分查找模板 II

分查找的高级模板。它用于查找需要访问数组中当前索引及其直接右邻居索引的元素或条件。

int binarySearch(int[] nums, int target){
if(nums == null || nums.length == 0)
return -1;
int left = 0, right = nums.length;
while(left < right){
// Prevent (left + right) overflow
int mid = left + (right - left) / 2;
if(nums[mid] == target){ return mid; }
else if(nums[mid] < target) { left = mid + 1; }
else { right = mid; }
}
// Post-processing:
// End Condition: left == right
if(left != nums.length && nums[left] == target) return left;
return -1;
}

关键属性

  • 一种实现二分查找的高级方法。
  • 查找条件需要访问元素的直接右邻居。
  • 使用元素的右邻居来确定是否满足条件,并决定是向左还是向右。
  • 保证查找空间在每一步中至少有 2 个元素。
  • 需要进行后处理。 当你剩下 1 个元素时,循环 / 递归结束。 需要评估剩余元素是否符合条件。

2.3 二分查找模板 III

模板 3 是二分查找的另一种独特形式。它用于搜索需要访问当前索引及其在数组中的直接左右邻居索引的元素或条件。

int binarySearch(int[] nums, int target) {
if (nums == null || nums.length == 0)
return -1;
int left = 0, right = nums.length - 1;
while (left + 1 < right){
// Prevent (left + right) overflow
int mid = left + (right - left) / 2;
if (nums[mid] == target) {
return mid;
} else if (nums[mid] < target) {
left = mid;
} else {
right = mid;
}
}
// Post-processing:
// End Condition: left + 1 == right
if(nums[left] == target) return left;
if(nums[right] == target) return right;
return -1;
}

点击下方,第一时间了解华为云新鲜技术~

华为云博客_大数据博客_AI博客_云计算博客_开发者中心-华为云

以上内容来源于网络,由“WiFi之家网”整理收藏!

原创文章,作者:电脑教程,如若转载,请注明出处:https://www.224m.com/197056.html

(0)
电脑教程电脑教程
gps网络时间同步时钟简介(gps时间同步时区)
上一篇 2022年12月26日 11:35
风扇转转停停开不了机怎么办(开不了机 风扇转转停停)
下一篇 2022年12月26日 11:43

相关推荐

  • 华硕路由器设置双网络协议(华硕路由器售后服务电话)

    随着互联网的发展,越来越多的人开始关注网络安全和性能。华硕路由器作为一款高性能路由器,备受用户青睐。今天,我们来介绍一下如何设置双网络协议。 什么是双网络协议呢?简单来说,就是一台…

    网络 2025年3月21日
    274
  • 路由器经常断网需要重启才能恢复(图文)

    【导读】路由器经常断网需要重启才能恢复,下面就是WiFi之家网整理的网络知识百科,来看看吧!大家好,我是191路由器网小编,上述问题将由我为大家讲解。路由器经常断网需要重启才能恢复的原因如下:  1、局

    2021年7月9日
    69.7K
  • 海南工业无线路由器设置(工业级无线路由器哪款好)

    随着工业领域的不断发展,现在越来越多的企业开始关注工业级无线路由器的使用,毕竟无线网络在工业生产中的应用越来越广泛。 而其中海南工业无线路由器的设置也是十分重要的一部分,下面就来简…

    网络 2024年12月4日
    137
  • 网速不稳定是什么原因网速不稳定的解决方法(图)

    原标题:"网速不稳定是什么原因?网速不稳定的解决方法"相关电脑问题教程分享。 - 来源:WiFi之家网。网速不稳定是什么原因?很多用户在上网的时候,出现网速不稳定的情况,又不知道网速不稳定是什么原因,特

    2021年7月20日
    12.3K
  • re.tenda cn网址-tendawifi.com路由器设置界面.

    re.tendacn网址本文目录tendawifi.com路由器设置界面?笔记本如何设置tenda无线路由器?如何将路由器恢复为出厂设置-以腾达Tenda为例?重新换了路由器,腾达A301扩展器怎么重新设置?腾达a9无线信号扩展器怎么设置?tendawifi.com路由器设置界面?1:将你的手机与腾达无线路由器的WIFI连接上(新的腾达无线路由器的连接名字写在路由器的背面)2:连接好了WI

    2023年5月8日
    424
  • 使用WIFI上网信号不稳定的原因

    Wi-Fi上网问题频现链接Wi-Fi网络经常出现上网不佳的问题。对此有业内专家分析表示,原因主要是因为路由器或智能手机

    常见问题 2020年9月11日
    6.8K
  • 水星路由器增强版设置(水星路由器设置方法)

    水星路由器增强版设置 水星路由器增强版是一款功能强大的路由器,在使用前需要进行一些设置。 设置步骤: 连接路由器 首先,将路由器与电脑通过网线连接,确保两者连接正常。 登录路由器管…

    网络 2024年12月8日
    0
  • 怎么设置无线路由器隐藏(怎么设置无线路由器隐藏wifi)

    如何设置无线路由器隐藏wifi? 在家庭或者办公场所使用无线网络已成为了一种普遍的现象。而无线网络的安全问题也越来越受到了人们的重视。其中,一个重要的安全措施是隐藏路由器的SSID…

    网络 2024年9月15日
    137
  • 192.168.1.1登录官网 路由器登录界面

    【WiFi之家网- 192.168.1.1登录官网】路由器怎么用IP地址 192.168.1.1登录官网呢?1、把路由器正确连接光猫与电脑注意网线要连接正确,路由器、电脑、光猫(宽带网线)正确 连"

    192.168.1.1 2021年1月6日
    25.2K
  • tp-link和水星路由器设置无线桥接详细步骤

    原标题:"tp-link和水星路由器怎么设置无线桥接"相关路由器设置经验分享。 - 来源:WiFi之家网

    TP-link是国内用户非常多的路由器了,有朋友问了“tplink和水星怎么桥"

    2021年1月9日
    128.7K