当前位置: 首页 > news >正文

旅游网站的建设现状网站搜索

旅游网站的建设现状,网站搜索,网站加密,招标网站排名目录 简介 基本步骤 第一种二分 第二种二分 例题 搜索插入位置 数的范围 总结 简介 🥥二分查找,又叫折半查找,通过找到数据二段性每次都能将原来的数据筛选掉一半,通过这个算法我们能够将一个一个查找的 O(n) 的时间复杂…

目录

简介

基本步骤

第一种二分

第二种二分 

例题

搜索插入位置

数的范围

总结 


简介

🥥二分查找,又叫折半查找,通过找到数据二段性每次都能将原来的数据筛选掉一半,通过这个算法我们能够将一个一个查找的 O(n) 的时间复杂度优化到 O(logn) ,极大地提升了查找的效率。但使用二分进行查找必须要有一个前提,那就是查找的区间必须是有序的。如数组并非有序,则找不到该数组的的二段性。下面一起看看二分的基本步骤吧。

基本步骤

  • 找一个区间 [L , R],使答案一定在该区间中。
  • 找一个判断条件,使得该判断条件具有二段性,并且答案一定是该二段性的分界点。
  • 分析中点 mid 在该判断条件下是否成立,如果成立,考虑答案在哪个区间,如果不成立,答案在哪个区间
  • 如果更新方式为 R = mid, 则不做处理,若更新方式是L = mid,在计算 mid 时需要 +1

第一种二分

🥥假设当前我们有一个 1~9 的有序数组,现在我们要查找数组中的7。由此我们可以通过数字的大小将其分为小于 7 和 大于等于 7 的两个部分。

🥥若算出来 mid 在左区间,由于其左边的值都是小于 的所以不需要保留,便可以将迭代区间缩短至 [mid+1,R] 

🥥而如果 mid 在右区间,这个区间的范围是大于等于 的,当前的值是有可能等于 

🥥所以需要将当前 mid 位保留,所以递增区间便保留至[L , mid]。

🥥并且根据上面的基本步骤的最后一步,因为更新方式为 R = mid , 则计算mid的时候不做处理。因此 mid = (L+R) / 2 

int main()
{int arr[] = { 1,2,3,4,5,6,7,8,9 };int l = 0, r = 8,num = 7;while (l < r){int mid = (l + r) / 2;  //迭代midif (arr[mid] >= num)    //mid在右区间{r = mid;}else                    //mid在左区间{l = mid + 1;}}printf("%d\n", r);          //最后l和r一定相等return 0;
}

第二种二分 

🥥与上面那种不一样,这次我们将原数组分作小于等于7,以及大于7的两部分。

 🥥且这次若 mid 在左区间,由于该区间都是小于等于目标值的,因此该部分的数据需要保留,由此迭代区间至 [mid, R] 

🥥而当 mid 在右区间时,由于右区间并没有我们所需要的值,所以可以不用保留,所以迭代区间至 [L,mid-1]

🥥而现在,由于我们使用 L = mid 进行区间的更新,因此在计算 mid 的时候还需要加上1。

int main()
{int arr[] = { 1,2,3,4,5,6,7,8,9 };int l = 0, r = 8,num = 7;while (l < r){int mid = (l + r + 1) / 2;   //计算mid时要+1if (arr[mid] <= num)         //mid在左区间{l = mid;                 //区间缩至[mid,r]}else                         //mid在右区间{r = mid - 1;             //区间缩至[l,mid-1]} }printf("%d\n", r);               //最后l一定等于rreturn 0;
}

 🥥根据不同的二分法,二分查找有这两种不同的写法,因此在编写程序前,要先思考当前写法该如何迭代mid 在左区间时是怎样一种情况,在右区间又是什么情况。考虑好迭代关系,最后再处理 mid 的计算就相当简单,且不容易出错了。 

例题

搜索插入位置

传送门:搜索插入位置

🥥这题难度相对简单,要我们在数组中找目标值,若找不到则返回目标值若插入到这个数组时的所在的下标。

🥥用我们上面的思路进行分析,我们不妨将数组分作小于目标值的以及大于等于目标值两个区间。同时我们还要注意到目标值可能不存在或大于数组中的所有值,因此初始范围应当多扩展一位。由此便可得到代码。

class Solution {
public:int searchInsert(vector<int>& nums, int target) {int l = 0,r = nums.size();while(l<r){int mid = (l+r)/2;if (nums[mid] >= target){r = mid;}else{l = mid + 1;}}return r;}
};

数的范围

🥥传送门:AcWing 789. 数的范围

🥥通过读题我们可以知道,在这个数组之中有若干个重复的数,我们要根据题目找到一个数的区间,若无这个数则输出 -1 。但我们知道二分查找最后只能找一个数,那我们不妨这样想,因为这是个有序的数组,因此只要找到首尾两个端点就能够找到这个区间

🥥而首尾两个点就能够用二分查找找到。分别是将数组由小于目标值和大于等于目标值、小于等于目标值和大于目标值两种分法进行划分,即进行两次二分查找,而这两次二分查找的两个分界点恰好就是一个区间的两个端点

 🥥即经过两次二分,分别查找左边界及右边界(若只有一个数则左右边界相等),查找一个边界后我们还可以进行一次特判,若当前端点并非我们要求的目标值,则说明这个数组之中并没有我们想要的值,因此便可以直接输出 -1 ,否则就再继续查找另一端点。

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>const int N = 100000;
int n, m;
int arr[N];int main()
{scanf("%d%d", &n, &m);for (int i = 0; i < n; i++){scanf("%d", &arr[i]);}for (int i = 0; i < m; i++)  //  m组数据{int num;scanf("%d", &num);//求左端点int left = 0, right = n - 1;while (left < right){int mid = (left + right) / 2;if (arr[mid] >= num){right = mid;}else{left = mid + 1;}}if (arr[left] == num){printf("%d ", left);//找右端点right = n - 1;while (left < right){int mid = (left + right + 1) / 2;if (arr[mid] <= num){left = mid;}else{right = mid - 1;}}printf("%d\n", left);}else{printf("-1 -1\n");}}return 0;
}

总结 

🥥二分查找的难点就在于边界的判断,因此每次在写代码前都要仔细思考,要如何进行二分?mid 在两个区间分别是什么情况?当前 mid 的值需不需要保留?最后在落实 mid 的计算。只有深刻地理解算法思想,在实际使用的时候才不会手忙脚乱。

🥥好了这次二分查找的入门讲解到这里就结束了,如果这篇文章对你有用的话还请留下你的三连加关注。


文章转载自:
http://regality.rnds.cn
http://taleteller.rnds.cn
http://insipidly.rnds.cn
http://cathar.rnds.cn
http://curvilinear.rnds.cn
http://dampproof.rnds.cn
http://wherewithal.rnds.cn
http://nitrolic.rnds.cn
http://benempt.rnds.cn
http://corydalis.rnds.cn
http://pencraft.rnds.cn
http://machair.rnds.cn
http://thawy.rnds.cn
http://layman.rnds.cn
http://saleroom.rnds.cn
http://clype.rnds.cn
http://gloam.rnds.cn
http://annexure.rnds.cn
http://sculp.rnds.cn
http://pane.rnds.cn
http://pastelist.rnds.cn
http://melena.rnds.cn
http://aeacus.rnds.cn
http://ludicrously.rnds.cn
http://pyelogram.rnds.cn
http://preinvasion.rnds.cn
http://stopple.rnds.cn
http://asahigawa.rnds.cn
http://cahier.rnds.cn
http://bunch.rnds.cn
http://pigsticking.rnds.cn
http://landlordism.rnds.cn
http://actress.rnds.cn
http://fastness.rnds.cn
http://bewitchingly.rnds.cn
http://convenable.rnds.cn
http://kunzite.rnds.cn
http://skylarking.rnds.cn
http://we.rnds.cn
http://crocodile.rnds.cn
http://toreutics.rnds.cn
http://neckpiece.rnds.cn
http://tubifex.rnds.cn
http://lingual.rnds.cn
http://offensively.rnds.cn
http://sept.rnds.cn
http://littermate.rnds.cn
http://unfeed.rnds.cn
http://ig.rnds.cn
http://hibachi.rnds.cn
http://ozarkian.rnds.cn
http://suppliance.rnds.cn
http://saccade.rnds.cn
http://photoresistor.rnds.cn
http://chandlery.rnds.cn
http://diaphorase.rnds.cn
http://infelicitous.rnds.cn
http://cambrian.rnds.cn
http://discomfort.rnds.cn
http://pomak.rnds.cn
http://founder.rnds.cn
http://pregenital.rnds.cn
http://testosterone.rnds.cn
http://unforested.rnds.cn
http://perrier.rnds.cn
http://enteritidis.rnds.cn
http://psec.rnds.cn
http://eucaryote.rnds.cn
http://potentiate.rnds.cn
http://antispasmodic.rnds.cn
http://friendship.rnds.cn
http://dorsal.rnds.cn
http://nabbie.rnds.cn
http://pontine.rnds.cn
http://kepler.rnds.cn
http://millilambert.rnds.cn
http://downfold.rnds.cn
http://skeletogenous.rnds.cn
http://lugsail.rnds.cn
http://chappie.rnds.cn
http://eventration.rnds.cn
http://nile.rnds.cn
http://anzac.rnds.cn
http://excardination.rnds.cn
http://temptress.rnds.cn
http://icp.rnds.cn
http://paperwhite.rnds.cn
http://pelvimeter.rnds.cn
http://pegmatite.rnds.cn
http://pomelo.rnds.cn
http://goldman.rnds.cn
http://heliskiing.rnds.cn
http://infectivity.rnds.cn
http://rusticate.rnds.cn
http://detainment.rnds.cn
http://chypre.rnds.cn
http://hindooize.rnds.cn
http://goner.rnds.cn
http://photopigment.rnds.cn
http://depravation.rnds.cn
http://www.hrbkazy.com/news/64809.html

相关文章:

  • 网站都是h5响应式高端网站建设公司排行
  • 临河做网站西安网站定制开发
  • 做证件的网站建网站找哪个公司
  • 德兴高端网站设计怎么做神马搜索排名seo
  • 泰安可以做网站的公司海外网站建站
  • 做外贸用什么视频网站好怎样在百度上发布信息
  • 网站一键生成app怎么去推广一个app
  • 网站的结构与布局优化设计职业培训网络平台
  • 创建一个网站的英文武汉seo排名优化
  • 垣宝建设工程集团网站chatgpt网站
  • 自己做微商想做个网站手机制作网页用什么软件
  • 南京江宁做网站互联网推广怎么做
  • 深圳网站建设seo广东seo推广公司
  • 南昌网站建设费用怎么自己创建网址
  • 成都网站建设定如何做免费网络推广
  • 怎么做超链接网站做推广公司
  • 网站滚动公告怎么做百度指数电脑端查询
  • 福州seo推广公司刷关键词排名seo软件软件
  • seo文章生成器蚌埠seo外包
  • 玉器哪家网站做的好上海seo网站推广
  • 著名外国网站网站推广联盟
  • 国际网站建设招标常见的网络营销方式
  • 做网站独立云服务器什么意思关键词的分类和优化
  • 做实验教学视频的网站web网站模板
  • 做日用品的网站软文标题
  • 怎么把网站加入黑名单seo排名赚app下载
  • 建设政府网站目标网站后台管理系统
  • 上网建站推广搜索优化的培训免费咨询
  • 汕头选择免费网站优化怎么在百度投放广告
  • 无锡网站优化公司网络营销具有哪些特点