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

网站开发需要投入多少时间网站做接口排线方法

网站开发需要投入多少时间,网站做接口排线方法,做模版的网站,租号网站怎么做&#x1f31e; 题目&#xff1a; &#x1f30f;在有序数组A中&#xff0c;查找目标值target &#x1f30f;如果找到返回索引 &#x1f30f;如果找不到返回-1 算法描述解释前提给定一个内含n个元素的有序数组A&#xff0c;满足A0<A1<A2<<An-1,一个待查值target1设…

🌞 题目:

🌏在有序数组A中,查找目标值target
🌏如果找到返回索引
🌏如果找不到返回-1

算法描述解释
前提给定一个内含n个元素的有序数组A,满足A0<=A1<=A2<=·······<=An-1,一个待查值target
1设置left=0;right = n - 1
2如果left > right ,结束查找,没找到
3设置mid = (left + right )/2,mid为中间索引
4如果target < Am,设置right = mid -1,跳到第2步
5如果target > Am,设置left = mid +1,跳到第2步
6如果Am = target,结束查找,找到了

算法实现

 public  int binarySearch(int[] arr,int target) {int left = 0;int right = arr.length-1;while(left<=right) {int mid = (left+right)>>>1;if(target < arr[mid]) {right = mid - 1;}else if (arr[mid] < target) {left = mid + 1;}else {return mid;}}return -1;}

注解:

1.为什么while循环条件是left<=right,而不是left<right?
因为当left=right时,mid=left=right可能为我们想要查找的值

2.为什么mid = (left+right)>>>1,而不是(left+right)/2呢? >>>是无符号右移,无符号右移一位相当于除2取整。 不用(left+right)/2原因是,当left+right的值超过int类型的正整数最大范围,其值就会由正变负

在其他的资料中二分查找与这个代码不一样,

✈️ 二分查找的改动版

public static int binarySearch1(int[] arr,int target) {int left=0;int right = arr.length;      //第一处改动while(left < right) {        //第二处改动int mid = (left+right)>>>1;if(target < arr[mid]) {right = mid;          //第三处改动}else if (arr[mid] < target) {left = mid + 1;}else {return mid;}}return -1;}

⛵️注解

right=arr.length,作为一个边界存在,left可能为我们的查找目标,但是right一定不是我们要找到的目标

🚀图解演示:

查找13
在这里插入图片描述

⛽️在Java中其实已经提供了二分查找的方法binarySearch

public class Test {public static void main(String[] args) {int[] arr ={1,2,3,4,5,5,6};int target = Arrays.binarySearch(arr,3);System.out.println(target);}
}

🚠运行结果:

2

在这里插入图片描述

🚩二分查找对重复元素的处理

📍重复元素最靠右的元素

说明:查找元素为重复元素的话,会查找到最右边的重复元素
Returns:
找到则返回最靠右索引
找不到返回-1

//重复元素最靠右的元素
public class Test5 {public static int binarySearch2(int[] arr,int target) {int left = 0;int right = arr.length-1;int cand = -1;while (left <= right) {int mid = (left + right)>>>1;if(target < arr[mid]) {right = mid-1;} else if (arr[mid] < target) {left = mid+1;}else {cand = mid;left = mid+1;}}return cand;}
}

说明:返回<=target的最右边的索引
Returns:
找到则返回最靠右索引
找不到返回小于target最右边的索引

 public static int binarySearchRightMost(int[] arr,int target){int left = 0;int right = arr.length-1;while(left <= right) {int mid = (left + right )>>>1;if(target < arr[mid]){right = mid-1;}else {left = mid + 1;}}return left-1;}

📍重复元素最靠左的元素

说明:查找元素为重复元素的话,会查找到最左边的重复元素
Returns:
找到则返回最靠左索引
找不到返回-1

 public static int binarySearch2(int[] arr,int target) {int left = 0;int right = arr.length-1;int cand = -1;while (left <= right) {int mid = (left + right)>>>1;if(target < arr[mid]) {right = mid-1;} else if (arr[mid] < target) {left = mid+1;}else {cand = mid;right = mid - 1;}}return cand;}

说明:
返回>=target最左边的索引
Returns:
找到则返回最靠左索引
找不到返回比target大的最左边索引

 public static int binarySearchLeftMost(int[] arr,int target) {int left=0;int right = arr.length-1;while(left <= right) {int mid = (left + right)>>>1;if(target <= arr[mid]) {right = mid - 1;}else  {left = mid + 1;}}return left;}

图解:
在这里插入图片描述

🚆leetcode二分查找题

1️⃣1.给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。
⏩ 链接: 二分查找

提示:
你可以假设 nums 中的所有元素是不重复的。
n 将在 [1, 10000]之间。
nums 的每个元素都将在 [-9999,9999]之间。

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

2️⃣2.给定一个排序的整数数组 nums 和一个整数目标值 target ,请在数组中找到 target ,并返回其下标。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
请必须使用时间复杂度为 O(log n) 的算法。
⏩ 链接: 搜索插入位置

class Solution {public int searchInsert(int[] nums, int target) {int left=0;int right = nums.length-1;while(left <= right) {int mid = (left + right)>>>1;if(target <= nums[mid]) {right = mid - 1;}else  {left = mid + 1;}}return left;}
}

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

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

你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。
⏩ 链接: 在排序数组中查找元素的第一个和最后一个位置

class Solution {public int[] searchRange(int[] nums, int target) {int x=left(nums,target);if(x==-1){return new int[]{-1,-1};}else{return new int[]{x,right(nums,target)};}}public int left(int[] nums,int target) {int i=0;int j=nums.length-1;int cand=-1;while(i<=j){int  m=(i+j)>>>1;if(target<nums[m]){j=m-1;}else if(nums[m]<target){i=m+1;}else{cand=m;j=m-1;}}return cand;}public int right(int[] nums,int target) {int i=0;int j=nums.length-1;int cand=-1;while(i<=j){int  m=(i+j)>>>1;if(target<nums[m]){j=m-1;}else if(nums[m]<target){i=m+1;}else{cand=m;i=m+1;}}return cand;}
}
http://www.yayakq.cn/news/65609/

相关文章:

  • 建站saas做网站多大上行速度
  • 兰州微网站建设好的网站怎么建设
  • 高端品牌网站建设(杭州)做招商网站
  • 宝坻集团网站建设王晴儿 网站建设
  • 网站开发流程分为哪3个阶段wordpress时间调用
  • 不备案的网站的稳定吗国外视觉设计网站
  • 网站优化两大核心要素是什么企业网站做百度小程序
  • 外贸网站经典营销案例网页游戏制作工具
  • 杭州做绒毛鉴定网站建个什么网站好
  • wordpress怎样搭建网站做啥网站比较好赚钱
  • 长沙模板建网站需要多久模板网站是什么意思
  • 做零食网站怎么样wordpress交友主题免费
  • 怀柔手机网站建设做遗嘱的网站有哪些
  • 含山县查询建设工程的网站嘉兴网站建设兼职
  • 国外科技网站欣赏手机网站开发+手机模拟器
  • 旅行社做境外购物网站安徽网站建设系统
  • 网站建设的实验结论房产最新消息今天新闻
  • 有经验的大连网站建设seo优化运营
  • 滨州公司网站建设静态网站公用头部 调用标题
  • 整站优化温州怎么做?假快递单制作软件app
  • 网站编辑器是怎么做的google 网站收录
  • 网站维护及更新方案互联网信息投诉平台入口
  • 山西天镇建站哪家好做网站微信朋友圈应该怎么发
  • 如何分析网站优缺点昭通学院教务管理系统
  • 阿里巴巴怎么做企业网站共享会议室租赁平台
  • 某网站优化方案网站建设包含哪些费用
  • php做的购物网站系统下载wordpress 改变网页
  • 易营宝自助建站系统海口模板网站建站
  • 网站设计的图片wordpress未验证邮箱用户
  • 企业网站模板素材网站设计概述