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

2089. 找出数组排序后的目标下标——O(n)做法!

       

        本题要求在一个已排序的数组 nums 中,找出所有等于目标值 target 的元素下标。若不存在这样的元素,则返回 {-1, -1}。解决该问题有两种主要方法:二分查找法和统计计数法。

二分查找法:首先对数组进行排序,然后通过二分查找确定 target 的下界(即第一个大于等于 target 的元素位置)和上界(即最后一个小于等于 target 的元素位置),这两个位置的交集即为所有等于 target 的元素下标。

        二分代码请看34. 在排序数组中查找元素的第一个和最后一个位置——边界问题不清楚?结果不知道是left还是right?四种大小关系不会转化?一篇文章告诉你!-CSDN博客

   

        采用二分查找法:首先确定大于等于目标值的最小索引,再找出小于等于目标值的最大索引,这两个索引之间的范围即为等于目标值的区间。

class Solution {
public:int lower_bound(vector<int>& nums,int target) {int n = nums.size();int left = 0,right = n - 1;while (left <= right) {int  mid = (right - left) / 2 + left;if (nums[mid] < target) {left = mid + 1;}else{right = mid - 1;}}return left;}vector<int> targetIndices(vector<int>& nums, int target) {ranges::sort(nums);int n = nums.size();int start = lower_bound(nums,target);if (start == n || nums[start] != target) return {};int end = lower_bound(nums,target + 1) - 1;vector<int> ans;for (int i = start;i <= end;i++){ans.emplace_back(i);}return ans;}
};

        时间复杂度:O(nlogn)

        空间复杂度:O(1)       

        统计小于和等于目标值的方法:通过less_count记录小于目标值的元素数量,equal_count记录等于目标值的元素数量。在排序后的数组中,less_count表示第一个目标值的下标,less_count+1表示第二个目标值的下标,依此类推,直到less_count + equal_count - 1

        例如:

输入:nums = [1,2,5,2,3], target = 2
输出:[1,2]

     

排序后的数组为 [1, 2, 2, 3, 5],其中 less = 1equal = 2,最终结果为 [1, 2]

class Solution {
public:vector<int> targetIndices(vector<int>& nums, int target) {int less_count = 0,equal_count = 0;for (int it:nums) {if (it < target) less_count++;else if (it == target) equal_count++;}vector<int> ans(equal_count);iota(ans.begin(),ans.end(),less_count);return ans;}
};

        时间复杂度:O(n)

        空间复杂度:O(1)

http://www.xdnf.cn/news/6426.html

相关文章:

  • OpenCV CUDA模块中逐元素操作------数学函数
  • 原生微信小程序 textarea组件placeholder无法换行的问题解决办法
  • Secs/Gem第五讲(基于secs4net项目的ChatGpt介绍)
  • window 显示驱动开发-命令和 DMA 缓冲区简介
  • VBA编程时如何加密数据库连接的账号密码?
  • Ubuntu 编译SRS和ZLMediaKit用于视频推拉流
  • 高效管理多后端服务:Nginx 配置与实践指南
  • 《Python星球日记》 第78天:CV 基础与图像处理
  • 二程运输的干散货船路径优化
  • 图片、音频、视频都能转?简鹿格式工厂了解一下
  • ollama 升级换源
  • Buildroot 移植MiniGUI
  • 牛客网NC21994:分钟计算
  • 【匹配】Needleman–Wunsch
  • 深入理解 Cortex-M 的中断输入和挂起行为
  • RedHat7 如何更换yum镜像源
  • SAM微调fine-tune/PEFT系列论文整理
  • vue-quill-editor富文本编辑器
  • PYTHON训练营DAY26
  • 开发技术.前端开发相关问题
  • RiDoc:高效文档扫描与图像处理工具,助力高效办公
  • 语音识别——通过PyAudio录入音频
  • Secs/Gem第六讲(基于secs4net项目的ChatGpt介绍)
  • gRPC为什么高性能
  • 图神经网络如何模拟人类“理解场景”的过程?
  • 连接指定数据库时提示not currently accepting connections
  • 从代码学习深度学习 - 实战 Kaggle 比赛:图像分类 (CIFAR-10 PyTorch版)
  • Docker构建Nginx、PHP、MySQL及WordPress部署及解释
  • 2025 后端自学UNIAPP【项目实战:旅游项目】5、个人中心页面:微信登录,同意授权,获取用户信息
  • 作业帮Java后台开发面试题及参考答案(下)