《算法题讲解指南:优选算法-二分查找》--23.寻找旋转排序数组中的最小值,24.0~n-1中缺失的数字

《算法题讲解指南:优选算法-二分查找》--23.寻找旋转排序数组中的最小值,24.0~n-1中缺失的数字

🔥小叶-duck个人主页

❄️个人专栏《Data-Structure-Learning》

《C++入门到进阶&自我学习过程记录》《算法题讲解指南》--从优选到贪心

未择之路,不须回头
已择之路,纵是荆棘遍野,亦作花海遨游


目录

23.寻找旋转排序数组中的最小值

题目链接:

题目描述:

题目示例:

解法(二分查找):

算法思路:

C++算法代码:(以nums[ n - 1 ]为参照物)

C++算法代码:(以nums[ 0 ]为参照物)

算法总结及流程解析:

24.0~n-1中缺失的数字

题目链接:

题目描述:

题目示例:

解法(二分查找):

算法思路:

C++算法代码:

算法总结及流程解析:

结束语


23.寻找旋转排序数组中的最小值

题目链接:

153. 寻找旋转排序数组中的最小值 - 力扣

题目描述:

题目示例:

解法(二分查找):

算法思路:

      题目中的数组规则如下图所示:

      其中 C 点就是我们要求的点。
      二分的本质:找到一个判断标准,使得查找区间能够一分为二。

      通过图像我们可以发现,【A,B】 区间内的点都是严格大于 D 点的值的,C 点的值是严格小于 D 点的值的。但是当【C,D】区间只有一个元素的时候,C 点的值是可能等于 D 点的值的。

      因此,初始化左右两个指针 left,right:
      然后根据 mid 的落点,我们可以划分下一个查询的区间:

  • 当 mid 在【A,B】区间的时候,也就是 mid 位置的值严格大于 D 点的值,下一次查询区间在【mid+1,right】上;
  • 当 mid 在【C,D】区间的时候,也就是 mid 位置的值严格小于等于 D 点的值,下次查询区间【left,mid】在上。

      当区间长度变成 1 的时候,就是我们要找的结果。

C++算法代码:(以nums[ n - 1 ]为参照物)

class Solution { public: int findMin(vector<int>& nums) { //选择nums[n - 1]作为参照物 int left = 0; int right = nums.size() - 1; while(left < right) { int mid = left + (right - left) / 2; if(nums[mid] > nums[nums.size() - 1]) { left = mid + 1; } else { right = mid; } } return nums[left]; } };

C++算法代码:(以nums[ 0 ]为参照物)

class Solution { public: int findMin(vector<int>& nums) { //选择nums[0]作为参照物 int left = 0; int right = nums.size() - 1; while(left < right) { int mid = left + (right - left + 1) / 2; if(nums[mid] >= nums[0]) { left = mid; } else { right = mid - 1; } }//循环结束left与right相遇的位置是数组最大值, //left+1位置则是最小值(数组不是一直递增的情况) if(left == nums.size() - 1)//特殊情况:旋转到数组一直递增 { return nums[0]; } return nums[left + 1]; } };

算法总结及流程解析:

24.0~n-1中缺失的数字

题目链接:

LCR 173. 点名 - 力扣(LeetCode)

题目描述:

题目示例:

解法(二分查找):

算法思路:

      关于这道题中,时间复杂度为 O(N) 的解法有很多种,而且也都比较好想到,这里就不再赘述。本题我们主要介绍的是一个时间复杂度为 O(logN) 的最优解法二分法:

在这个升序的数组中,我们发现:

  • 在第一个缺失位置的左边,数组内元素都是与数组下标相等的;
  • 在第一个缺失位置的右边,数组内的元素都是与数组下标不相等的。

因此,我们可以利用这个【二段性】,来使用【二分查找】算法。

C++算法代码:

class Solution { public: int takeAttendance(vector<int>& records) { int left = 0; int right = records.size() - 1; while(left < right) { int mid = left + (right - left) / 2; if(mid >= records[mid]) { left = mid + 1; } else { right = mid; } } if(left == records[left]) { return records[left] + 1; } return records[left] - 1; } };

算法总结及流程解析:

结束语

      到此,23.寻找旋转排序数组中的最小值,24.0~n-1中缺失的数字 这两道算法题就讲解完了。旋转排序数组最小值:利用区间二段性,比较中点与右端点值,收缩查找范围至单个元素。缺失数字查找:根据元素值与下标关系二分,定位首个不匹配位置。希望大家能有所收获!

Read more

Java Web开发基础与Servlet核心技术

Java Web开发基础与Servlet核心技术

Java Web开发基础与Servlet核心技术 15.1 学习目标与重点提示 学习目标:掌握Java Web开发的核心概念与Servlet技术的使用方法,包括Web应用的结构、Servlet的定义与使用、HTTP请求与响应的处理、会话管理、过滤器与监听器的使用,学会在实际开发中处理Web应用问题。 重点:Web应用的结构(目录结构、配置文件)、Servlet的定义与使用(Servlet接口、HttpServlet类、注解配置)、HTTP请求与响应的处理(Request、Response对象)、会话管理(Session、Cookie)、过滤器与监听器的使用、Web开发的实际应用场景。 15.2 Web开发概述 Java Web开发是用于处理Web应用的机制。 15.2.1 Web开发的定义 定义:Web开发是用于处理Web应用的机制。 作用: * 实现Web应用的开发。 * 实现客户端与服务器之间的通信。 * 实现动态网页的生成。 * 实现Web应用的部署与维护。 ✅ 结论:Web开发是用于处理Web应用的机制,作用是实现Web应用的开发、客户端与服务器之间的通

By Ne0inhk

互联网大厂Java求职者面试实录与技术深度解析

互联网大厂Java求职者面试实录与技术深度解析 本文基于互联网大厂Java开发职位的求职者面试场景展开,通过严肃的面试官与幽默的谢飞机程序员的对话形式,展现三轮循序渐进的技术提问与解答。每轮包含3-5个相关问题,涉及核心Java语言、热门框架、微服务架构、数据库、缓存、安全等技术栈,同时结合多个业务场景如电商、内容社区、智慧城市等。 第一轮:Java核心与Web框架基础 面试官(严肃): 1. 请简述Java 8中引入的Stream API的优势及使用场景? 2. 在Spring Boot中如何实现一个RESTful API?请写一个简单示例。 3. 你了解WebFlux吗?它与Spring MVC的区别是什么? 谢飞机: 对Stream API我用过很多,比如用它来过滤集合数据,代码简洁性能也好。Spring Boot写REST API的话,用@RestController注解,写个GET接口很方便。 WebFlux是响应式非阻塞的,跟传统的Spring MVC阻塞模式不一样,适合高并发场景。 面试官:不错,继续保持。 第二轮:

By Ne0inhk
Vibe Coding - Claude Code 做 Java 项目 AI 结对编程最佳实践

Vibe Coding - Claude Code 做 Java 项目 AI 结对编程最佳实践

文章目录 * 概述 * 一、Claude Code + Developer Kit 是什么 * 1. Claude Code:类 IDE 的 AI 开发伴侣 * 2. Developer Kit:给 Claude 装上一整套 Java 技能包 * 二、快速上手:把 Developer Kit 装进你的 Java 项目 * 1. 安装到本机 / CLI 环境 * 2. 安装到具体的 Java 项目(重点) * 三、日常开发:Claude 作为 Java 结对编程伙伴 * 1. 从领域模型到完整 CRUD(

By Ne0inhk
Java 时间类(上):JDK7 及以前时间类 Date、SimpleDateFormat、Calendar 最全总结

Java 时间类(上):JDK7 及以前时间类 Date、SimpleDateFormat、Calendar 最全总结

🏠个人主页:黎雁 🎬作者简介:C/C++/JAVA后端开发学习者 ❄️个人专栏:C语言、数据结构(C语言)、EasyX、JAVA、游戏、规划、程序人生 ✨ 从来绝巘须孤往,万里同尘即玉京 文章目录 * Java 时间类(上):JDK7 及以前时间类 Date、SimpleDateFormat、Calendar 最全总结 🕒 * 📝 文章摘要 * 一、时间相关基础知识点 ⏱ * 1. 时间标准 * 2. 时间单位与换算 * 二、Date 时间类 📅 * 1. 概述 * 2. 构造方法 * 3. 成员方法 * 4. 代码示例 * 三、SimpleDateFormat 格式化与解析 ✍️ * 1. 作用

By Ne0inhk