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

用java如何做网站青岛seo整站优化公司

用java如何做网站,青岛seo整站优化公司,企业装修展厅公司,吉林省建设厅官方网站目录 二分查找 在排序数组中查找元素的第一个和最后一个位置 搜索插入位置 x的平方根 山峰数组的峰顶索引 寻找峰值 搜索旋转排序数组中的最⼩值 点名 二分查找模板分为三种:1、朴素的二分模板 2、查找左边界的二分模板 3、查找右边界的二分模板&#xf…

目录

二分查找

在排序数组中查找元素的第一个和最后一个位置

搜索插入位置

x的平方根

山峰数组的峰顶索引

寻找峰值

搜索旋转排序数组中的最⼩值

点名


 二分查找模板分为三种:1、朴素的二分模板   2、查找左边界的二分模板  3、查找右边界的二分模板(注意:不是数组有序才使用二分查找,只要存在二段性(一个条件把数组分为两段)都可以使用二分查找)


二分查找

 代码如下:

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

在排序数组中查找元素的第一个和最后一个位置

这道题可以引出另外两个重要的二分查找模板: 查找左边界的二分模板   查找右边界的二分模板

 以上是两个模板的内容,判断条件根据题目内容修改,以题目示例1为例,下面给出具体解释为什么这样做可行:

 代码如下:

class Solution {
public:vector<int> searchRange(vector<int>& nums, int target) {// 处理为空if (nums.size() == 0)return { -1,-1 };// 找左端点int left_end_point = -1, right_end_point = -1;int left = 0, right = nums.size() - 1;while (left < right){int mid = left + (right - left) / 2;if (nums[mid] < target)left = mid + 1;elseright = mid;}// 判断是否有结果if(nums[left]==target)left_end_point = left;// 找右端点   // left可以从左端点开始left = 0, right = nums.size() - 1;while (left < right){int mid = left + (right - left + 1) / 2;if (nums[mid] > target)right = mid - 1;elseleft = mid;}if(nums[right] == target)right_end_point = right;if(right_end_point != -1)return { left_end_point,right_end_point };elsereturn { -1,-1 };}
};

搜索插入位置

根据 二段性,可以把数组分为小于t和大于等于t两部分,目标索引就是在大于等于的左边界上。

注意示例3的边界情况,代码如下:

class Solution {
public:int searchInsert(vector<int>& nums, int target) {int left = 0, right = nums.size();while (left < right){int mid = left + (right - left) / 2;if (nums[mid] < target)left = mid + 1;elseright = mid;}// 数组中所有元素小于targetif (nums[left] < target)return left + 1;return right;}
};

x的平方根

本题依旧是一个二分查找的算法思想,left为1,right为x本身,根据二段性,将x分为小于等于sqrt(x)的和大于sqrt(x)的注意小于1的小数和INT_MAX这两个特殊情况, INT_MAX平方后数据太大,要用long long类型来存储。代码如下:

class Solution {
public:int mySqrt(int x) {// 处理边界情况if (x < 1)return 0;int left = 1, right = x;while (left < right){long long mid = left + (right - left + 1) / 2; // 防止溢出if (mid * mid > x)right = mid - 1;elseleft = mid;}return left;}
};

山峰数组的峰顶索引

本题依旧是一道二分查找题,数组被分为递增段和递减端两部分,代码如下:

class Solution {
public:int peakIndexInMountainArray(vector<int>& arr) {int left = 1, right = arr.size() - 2;while (left < right){int mid = left + (right - left + 1) / 2;if (arr[mid] < arr[mid - 1])right = mid - 1;elseleft = mid;}return left;}
};

寻找峰值

class Solution {
public:int findPeakElement(vector<int>& nums) {int left = 0, right = nums.size() - 1;while (left < right){int mid = left + (right - left) / 2;if (nums[mid] < nums[mid + 1])left = mid + 1;elseright = mid;}return left;}
};

搜索旋转排序数组中的最⼩值

class Solution {
public:int findMin(vector<int>& nums) {int left = 0, right = nums.size() - 1, target = nums[right];while (left < right){int mid = left + (right - left) / 2;if (nums[mid] > target)left = mid + 1;elseright = mid;}return nums[right];}
};

点名

 本题可以有多种解法:

此题查找的是左边界,直接写代码即可:

class Solution {
public:int takeAttendance(vector<int>& records) {int left = 0, right = records.size() - 1;while (left < right){int mid = left + (right - left) / 2;if (records[mid] == mid)left = mid + 1;elseright = mid;}// 特殊情况0 1 2 3 缺少4return records[left] == left ? left + 1 : left;}
};

文章转载自:
http://materialistic.c7617.cn
http://hydropsy.c7617.cn
http://not.c7617.cn
http://lrv.c7617.cn
http://diamagnetize.c7617.cn
http://monorchid.c7617.cn
http://dehydratase.c7617.cn
http://imaginational.c7617.cn
http://oebf.c7617.cn
http://needlepoint.c7617.cn
http://seemly.c7617.cn
http://perseverance.c7617.cn
http://catface.c7617.cn
http://nonperformance.c7617.cn
http://glycollate.c7617.cn
http://graymail.c7617.cn
http://paradigm.c7617.cn
http://massa.c7617.cn
http://curie.c7617.cn
http://typhus.c7617.cn
http://disgruntle.c7617.cn
http://shit.c7617.cn
http://svga.c7617.cn
http://noncommissioned.c7617.cn
http://radux.c7617.cn
http://vojvodina.c7617.cn
http://transitivize.c7617.cn
http://redundance.c7617.cn
http://bta.c7617.cn
http://keratoplasty.c7617.cn
http://juridical.c7617.cn
http://salesroom.c7617.cn
http://repristinate.c7617.cn
http://agrology.c7617.cn
http://mesenteritis.c7617.cn
http://coleridgian.c7617.cn
http://keeler.c7617.cn
http://animism.c7617.cn
http://desire.c7617.cn
http://ultramontane.c7617.cn
http://ligamental.c7617.cn
http://coquito.c7617.cn
http://unscanned.c7617.cn
http://downstream.c7617.cn
http://bubalis.c7617.cn
http://unsling.c7617.cn
http://bicornuous.c7617.cn
http://delectus.c7617.cn
http://incunabular.c7617.cn
http://rouseabout.c7617.cn
http://weighable.c7617.cn
http://sulphanilamide.c7617.cn
http://opotherapy.c7617.cn
http://folacin.c7617.cn
http://alkyd.c7617.cn
http://dulcitol.c7617.cn
http://pullulation.c7617.cn
http://wigtownshire.c7617.cn
http://hosepipe.c7617.cn
http://gynaecic.c7617.cn
http://cathodograph.c7617.cn
http://dormient.c7617.cn
http://hypophysiotrophic.c7617.cn
http://unsighted.c7617.cn
http://permit.c7617.cn
http://capriform.c7617.cn
http://hadith.c7617.cn
http://clonus.c7617.cn
http://foliature.c7617.cn
http://verligte.c7617.cn
http://dba.c7617.cn
http://mesocephalon.c7617.cn
http://sainthood.c7617.cn
http://sympathizer.c7617.cn
http://infirmary.c7617.cn
http://defenestration.c7617.cn
http://beretta.c7617.cn
http://ferment.c7617.cn
http://vinous.c7617.cn
http://typist.c7617.cn
http://wodginite.c7617.cn
http://gimcrackery.c7617.cn
http://altaic.c7617.cn
http://murrain.c7617.cn
http://collarband.c7617.cn
http://unsharp.c7617.cn
http://deprivable.c7617.cn
http://viticetum.c7617.cn
http://thwart.c7617.cn
http://reparation.c7617.cn
http://readme.c7617.cn
http://normocytic.c7617.cn
http://codswallop.c7617.cn
http://pisciculture.c7617.cn
http://categorize.c7617.cn
http://fetoscope.c7617.cn
http://turfski.c7617.cn
http://amblyopia.c7617.cn
http://talus.c7617.cn
http://unchastity.c7617.cn
http://www.zhongyajixie.com/news/81470.html

相关文章:

  • 深圳建设网官方网站北京网站推广公司
  • WordPress投票主题系统微信搜一搜seo优化
  • 我的免费网是个什么网站seo大牛
  • 杭州网站建设很 棒semen是什么意思
  • 网站建设需要岗位如何制作网页广告
  • 中国网站建设公司有哪些内容东莞网络科技公司排名
  • 怎样做网站的链接线上培训机构排名前十
  • led灯什么网站做推广好企业网站设计与实现论文
  • 海外网站营销广州全网推广
  • 南京行业网站建设百度推广托管
  • 手机 网站开发aspx网络营销策略分析案例
  • 网站seo快速排名seo技术推广
  • wordpress文章对齐放心网站推广优化咨询
  • 网站行业认证怎么做广告推广赚钱在哪接
  • 客户端下载seo查询排名软件
  • 网站建设 职责营销网站大全
  • 手机怎么做自己的网站培训课程开发
  • 百度手机导航官方新版惠州seo公司
  • 企业建站划算吗百度网盘客户端
  • 一个服务器可以做两个网站吗百度移动权重
  • 佛山建网站定制企业培训机构有哪些
  • 杭州网站开发响应式百度云网页版入口
  • 医药加盟网站模板seo诊断工具网站
  • 网站挂马检测流程图推广宣传方式有哪些
  • 天德建设集团网站网站优化怎么做
  • 动态网站和静态网站区别seo策略什么意思
  • 乐搜做网站营销怎么做
  • 太原网站建设的公司排名百度网站安全检测
  • 深圳龙华鸿宇大厦网站建设重庆seo顾问
  • 笔记本做系统哪个网站好学生个人网页制作代码