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

LeetCode 35.搜索插入位置

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。

请必须使用时间复杂度为 O(log n) 的算法。

示例 1:

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

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

输入: nums = [1,3,5,6], target = 7
输出: 4

提示:

1 <= nums.length <= 104
-104 <= nums[i] <= 104
nums 为 无重复元素 的 升序 排列数组
-104 <= target <= 104

直接二分搜索即可:

func searchInsert(nums []int, target int) int {left := 0right := len(nums) - 1res := len(nums)for left <= right {mid := int(left + (right - left) / 2)if nums[mid] >= target {res = midright = mid - 1} else if nums[mid] < target {left = mid + 1}}return res
}

C++解法:

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

此算法时间复杂度为O(logn),空间复杂度为O(1)。

http://www.lryc.cn/news/343684.html

相关文章:

  • 速来get!多微信聚合聊天功能大揭秘!
  • 【跟我学RISC-V】(一)认识RISC-V指令集并搭建实验环境
  • 如何使用google.protobuf.Struct?
  • Vue3 + TS + Element-Plus 封装的 Dialog 弹窗组件
  • 大数据技术概述_4.大数据的应用领域
  • ABB RobotStudio学习记录(一)新建工作站
  • 雷达通信一体化(含WCSP2023会议论文集学习)
  • 特斯拉擎天柱机器人:工厂自动化的未来
  • 【管理咨询宝藏93】大型制造集团数字化转型设计方案
  • 【数学建模】天然肠衣搭配问题
  • Dockerfile实践java项目
  • 【管理咨询宝藏96】企业数字化转型的中台战略培训方案
  • 【webrtc】MessageHandler 3: 基于线程的消息处理:以sctp测试为例
  • redisson 使用脚本实现将一个队列的元素弹出并推入另一个队列的原子操作
  • 基于Springboot的校园新闻管理系统(有报告)。Javaee项目,springboot项目。
  • Windows环境下基于CMake构建Lua
  • LLM⊗KG范式下的知识图谱问答实现框架思想阅读
  • ue引擎游戏开发笔记(35)——为射击添加轨道,并显示落点
  • 路由策略与路由控制
  • JAVA版本的ATM编程问题记录
  • C#winfrom三层架构实现简单课程管理系统管理系统,三层架构实现增删改查
  • AI技术赋能下的视频监控方案是如何解决新能源汽车充电难问题的?
  • 长难句打卡5.6
  • PDF编辑器软件常见问题(技巧)总结
  • Dive into Deep Learning-优化算法(1)
  • Partisia Blockchain 生态首个zk跨链DEX现已上线
  • .NET操作 Access (MSAccess)
  • shell脚本,删除30天以前的日志,并将日志推送到nas,但运行出现/bin/bash^M。
  • 现身说法暑期三下乡社会实践团一个好的投稿方法胜似千军万马
  • 小程序账号设置以及request请求的封装