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

搭建织梦网站视频教程秦皇岛建设网招聘信息

搭建织梦网站视频教程,秦皇岛建设网招聘信息,网址解析ip地址,怎么做网站才能被收购二分查找 今日刷到二分查找,以前做过的题忘的一干二净;庆幸自己用新的方法做了出来两道“中等”题;(我都能做出来我认为应该标“简单”)由于之前题的难度基本在抄答案,所以停更几天。今天没抄答案就更新一…

二分查找

今日刷到二分查找,以前做过的题忘的一干二净;庆幸自己用新的方法做了出来两道“中等”题;(我都能做出来我认为应该标“简单”)由于之前题的难度基本在抄答案,所以停更几天。今天没抄答案就更新一下。

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

给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。

如果数组中不存在目标值 target,返回 [-1, -1]

你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。

示例 1:

输入:nums = [5,7,7,8,8,10], target = 8
输出:[3,4]

算法思路

“ 间复杂度为 O(log n) ,按照非递减顺序排列的整数数组 nums”两个提示说明要用到二分查找才能满足题目要求,直接写出二分查找基本函数biSearch(int[] nums, int target),并在主函数调用;若在nums中找到target,则返回target的索引mid,否则返回-1;若返回-1就表示没找到,则返回[-1,-1];由于是非递数组,若有多个target值应该是连续存在,故从mid向两侧开始寻找,返回[indexl,indexr]即可;+1,-1是因为while跳出循环前多+/-一次;

class Solution {public int[] searchRange(int[] nums, int target) {int left=0,right=nums.length-1;int temp=biSearch(nums,target);if(temp>=0){int indexr=temp, indexl=temp;while(indexr<=right&&nums[indexr]==nums[temp]){indexr++;}while(indexl>=0&&nums[indexl]==nums[temp]){indexl--;}return new int[]{indexl+1,indexr-1};}return new int[]{-1,-1};}public int biSearch(int[] nums, int target) {int left=0,right=nums.length-1;while(left<=right){int mid=(right-left)/2+left;if(nums[mid]==target){return mid;}if(nums[mid]>target){right=mid-1;}else{left=mid+1;}}return -1;}
}

结果

74.搜索二维矩阵 

给你一个满足下述两条属性的 m x n 整数矩阵:

  • 每行中的整数从左到右按非递减顺序排列。
  • 每行的第一个整数大于前一行的最后一个整数。

给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false 。

示例 1:

输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
输出:true

算法思路

“非递减”直接使用效率最高的二分查找;每行循环一次进行一次二分查找找到为止;

class Solution {public boolean searchMatrix(int[][] matrix, int target) {for(int[] num:matrix){if(biSearch(num,target)==true){return true;}}return false;}public boolean biSearch(int[] nums, int target){int left=0, right=nums.length-1;while(left<=right){int mid=(right-left)/2+left;if(nums[mid]==target){return true;}if(nums[mid]>target){right=mid-1;}else{left=mid+1;}}return false;}
}

 结果


 

http://www.yayakq.cn/news/595374/

相关文章:

  • 百度搜索推广流程汨罗网站seo
  • 青岛网站营销推广电子商务网站建设课程评价
  • 陕西网站推广公司装修找什么平台比较好
  • 做网站最好陕西省中小学教师培训网站
  • 北京做网站的公司排名妖精直播
  • 桂林网站开发公司北京网站建设1000zhu
  • 做网站推广那家好东莞广告公司有哪些
  • mvc做的游戏网站wordpress分段加载
  • 上海做网站建设的公司深圳有哪些大公司
  • 企业网站模板大全长沙线上注册推广公司
  • 广州 建设 招聘信息网站app开发公司投入
  • 怀安县网站建设宁波做网站公司
  • 请别人做网站签订合同wordpress jq
  • 品牌网站建设重點大蝌蚪如何建设一个不备案的网站
  • 只做网站哪个云服务器好怎么做点击文字进入的网站
  • 公司网站制作教程网站制作外包价格
  • 湖南服装网站建设WordPress单页随机
  • 网上拿手工做的网站开公司要多少钱才能注册
  • 张家口建设网站香奈儿网站建设的目标
  • 久商推网站建设建设集团公司网站
  • 网站建设考察试卷wordpress 局域网
  • 提供镇江网站建设推广平台有哪些适用于广告
  • 网站后台如何管理集团网站设计公司
  • 湖北省建设规划网站怎么做锅炉网站
  • 排名好的大连网站建设黔东南网站设计公司
  • 大型图片库网站建设建设部网站资质查询
  • 域名注册成功怎么做网站中国建设银行网站 纪念币预约
  • 怎么看网站的建设时间梁水才seo优化专家
  • 做恐怖网站苏州seo推广优化
  • 如何成为网站开发工程师网站开发的意义