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

数组算法——查询位置

需求

在这里插入图片描述

思路

  • 使用二分查找找到第一个值,以第一个值作为界限,分为左右两个区间
  • 在左右两个区间分别使用二分查找
  • 找左边的7,:找到中间位置的7之后,将中间位置的7作为结束位置,依次循环查找,知道start>end,返回start,这就是7第一次出现的位置
  • 找右边的7,:找到中间位置的7之后,将中间位置的7作为开始位置,依次循环查找,知道start>end,返回end,这就是7最后一次出现的位置

代码

左边索引

private static int getLeftIndex(int[] nums, int target) {int start = 0;int end = nums.length - 1;while (start <= end) {int mid = start + (end - start) / 2;if (nums[mid] == target) {end = mid - 1;} else if (nums[mid] < target) {start = mid + 1;} else {end = mid - 1;}}if (start >= nums.length || nums[start] != target) {return -1;}return start;
}

右边索引

private static int getRightIndex(int[] nums, int target) {int start = 0;int end = nums.length - 1;while (start <= end) {int mid = start + (end - start) / 2;if (nums[mid] == target) {start = mid + 1;} else if (nums[mid] < target) {start = mid + 1;} else {end = mid - 1;}}if (end < 0 || nums[end] != target) {return -1;}return end;
}

main函数 返回
leftIndex = 3
rightIndex = 5

int[] nums = {1,3,3,7,7,7,8,8,9};
int target = 7;
int leftIndex = getLeftIndex(nums, target);
int rightIndex = getRightIndex(nums, target);
System.out.println("leftIndex = " + leftIndex);
System.out.println("rightIndex = " + rightIndex);
http://www.lryc.cn/news/338033.html

相关文章:

  • 【解决leecode打不开的问题】使用chrome浏览器和其他浏览器均打不开leecode
  • 尝试在手机上运行google 最新开源的gpt模型 gemma
  • 56、巴利亚多利德大学、马德里卡洛斯三世研究所:EEG-Inception-多时间尺度与空间卷积巧妙交叉堆叠,终达SOTA!
  • ORA-00600: internal error code, arguments: [krbcbp_9]
  • uni-app实现分页--(2)分页加载,首页下拉触底加载更多
  • 前端工程化理解 (2024 面试题)
  • 10 Php学习:循环
  • FreeSWITCH 1.10.10 简单图形化界面17 - ubuntu22.04或者debian12 安装FreeSWITCH
  • ZStack Cloud 5.0.0正式发布——Vhost主存储、隔离PVLAN网络、云平台报警优化、灰度升级增强四大亮点简析
  • 商标没有去注册有哪些不好的影响!
  • 【小程序】常用方法、知识点汇总1
  • AugmentedReality之路-平面检测(5)
  • MQ:延迟队列
  • Element ui 动态展示表格列,动态格式化表格列的值
  • xxl-job调度任务原理解析
  • 实验2 路由器基本配置
  • docker部署安装整理
  • 为什么你明明拥有5年开发经验,但是依然写不出来一份简历?
  • 【ZZULIOJ】1062: 最大公约数(Java)
  • 北斗导航 | ARAIM算法的原理和性能测试
  • elasticsearch7安全配置--最低安全等级,用户名密码
  • 项目架构MVC,DDD学习
  • SQLite的PRAGMA 声明
  • 使用ArrayList.removeAll(List list)导致的机器重启
  • 如何在项目中使用uni-ui组件库
  • redis的过期策略和内存淘汰机制(redis篇)
  • Java中Runnable和Callable有什么不同?(企业真题)
  • 图机器学习导论
  • 地推网推拉新平台哪家强?一文清楚告诉你
  • Day:004(4) | Python爬虫:高效数据抓取的编程技术(数据解析)