news 2026/4/23 12:40:52

12.14 - 搜索旋转排序数组 判断两个结构体是否相等

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
12.14 - 搜索旋转排序数组 判断两个结构体是否相等

目录

1.搜索旋转排序数组

a.核心思想

b.思路

2.判断两个结构体是否相等

a.默认情况

b.特殊情况处理

c.重载 == 运算符


1.搜索旋转排序数组

33. 搜索旋转排序数组 - 力扣(LeetCode)https://leetcode.cn/problems/search-in-rotated-sorted-array/description/

class Solution { public: int search(vector<int>& nums, int target) { int left = 0; int right = nums.size() - 1; while (left <= right) { int mid = left + (right - left) / 2; if (nums[mid] == target) { return mid; } // 左半部分有序 if (nums[left] <= nums[mid]) { if (nums[left] <= target && target < nums[mid]) { right = mid - 1; } else { left = mid + 1; } } // 右半部分有序 else { if (nums[mid] < target && target <= nums[right]) { left = mid + 1; } else { right = mid - 1; } } } return -1; } };

a.核心思想

利用二分查找的思想,在旋转排序数组中高效地查找目标值。通过比较中间元素与两端的元素,确定哪一部分是有序的,再判断目标值是否在有序部分内,逐步缩小查找范围。

b.思路

① 初始化左右指针leftright分别指向数组的首尾。

② 在left <= right的条件下,计算中间下标mid

③ 如果nums[mid] == target,直接返回mid

④ 否则,判断nums[left]nums[mid]是否有序:

  • 如果nums[left] <= nums[mid],说明左半部分有序,判断target是否在nums[left]nums[mid]之间,如果是,则在左半部分继续查找,否则在右半部分查找。

  • 如果nums[left] > nums[mid],说明右半部分有序,判断target是否在nums[mid]nums[right]之间,如果是,则在右半部分继续查找,否则在左半部分查找。

⑤ 重复上述步骤,直到找到目标值或查找范围为空

c.步骤

  1. 初始化指针
    设置左指针left = 0,右指针right = nums.size() - 1

  2. 循环条件
    left <= right时,持续执行以下操作:

  3. 计算中间索引
    mid = left + (right - left) / 2(防止整数溢出)。

  4. 直接命中检查
    nums[mid] == target,立即返回mid

  5. 判断有序区间

    • 左半有序:当nums[left] <= nums[mid]
      • nums[left] <= target < nums[mid],收缩右边界right = mid - 1
      • 否则扩展左边界left = mid + 1
    • 右半有序:当nums[left] > nums[mid]
      • nums[mid] < target <= nums[right],扩展左边界left = mid + 1
      • 否则收缩右边界right = mid - 1
  6. 未找到处理
    循环结束后仍未找到目标值,返回-1

2.判断两个结构体是否相等

a.默认情况

当结构体所有成员均为基本类型(如intfloat)或支持比较的自定义类型时,可直接用==比较

struct Point { int x; int y; }; Point p1{1, 2}; Point p2{1, 2}; bool result = (p1 == p2); // 编译器自动逐成员比较,结果为 true

b.特殊情况处理

若结构体包含不支持比较的成员(如指针、数组),需手动比较

struct Data { int id; const char* name; // 指针类型无法直接比较 }; bool areEqual(const Data& a, const Data& b) { return (a.id == b.id) && (strcmp(a.name, b.name) == 0); // 手动比较指针指向的内容 }

c.重载==运算符

可自定义比较逻辑,使代码更简洁

struct Vector2D { float x; float y; }; // 重载 == 运算符 bool operator==(const Vector2D& a, const Vector2D& b) { return (a.x == b.x) && (a.y == b.y); } int main() { Vector2D v1{1.0f, 2.0f}; Vector2D v2{1.0f, 2.0f}; return (v1 == v2); // 直接使用 ==,结果为 true }

希望这些内容对大家有所帮助!

感谢大家的三连支持!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 8:22:27

3步掌握BlenderGIS真实地形生成:从数据到三维场景的完整指南

3步掌握BlenderGIS真实地形生成&#xff1a;从数据到三维场景的完整指南 【免费下载链接】BlenderGIS Blender addons to make the bridge between Blender and geographic data 项目地址: https://gitcode.com/gh_mirrors/bl/BlenderGIS 你是否曾经在Blender中辛苦调整…

作者头像 李华
网站建设 2026/4/23 11:12:14

MouseTester终极指南:专业鼠标性能测试工具完全解析

MouseTester终极指南&#xff1a;专业鼠标性能测试工具完全解析 【免费下载链接】MouseTester 项目地址: https://gitcode.com/gh_mirrors/mo/MouseTester 还在为鼠标响应延迟、光标漂移而烦恼吗&#xff1f;MouseTester这款专业的鼠标性能测试工具将为你提供科学的数据…

作者头像 李华
网站建设 2026/4/23 11:11:42

华硕性能优化:G-Helper替代方案的场景化配置指南

华硕性能优化&#xff1a;G-Helper替代方案的场景化配置指南 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops. Control tool for ROG Zephyrus G14, G15, G16, M16, Flow X13, Flow X16, TUF, Strix, Scar and other models 项目地址: ht…

作者头像 李华
网站建设 2026/4/23 12:36:11

数据增强在小型卷积神经网络中的有效性探究

在深度学习的模型构建中&#xff0c;数据增强&#xff08;Data Augmentation&#xff09;通常被视为提升模型性能和鲁棒性的“关键武器”。然而&#xff0c;是否所有增强技术在任何情况下都能带来正向收益&#xff1f;模型架构的容量&#xff08;Capacity&#xff09;和卷积类型…

作者头像 李华
网站建设 2026/4/18 3:08:43

CSS Border(边框)

CSS Border(边框) 在网页设计中,边框是构成视觉元素和布局的重要组成部分。CSS(层叠样式表)提供了丰富的边框属性,使得开发者能够灵活地控制网页元素的边框样式。本文将详细介绍CSS边框的相关知识,包括边框的样式、宽度、颜色、圆角等属性,帮助开发者更好地理解和运用边…

作者头像 李华
网站建设 2026/4/20 13:29:29

Maven 构建配置文件

Maven 构建配置文件 引言 Maven 是一个强大的项目管理工具,它可以帮助开发者简化构建、测试、文档和报告等过程。在 Maven 的使用过程中,配置文件起到了至关重要的作用。本文将详细介绍 Maven 构建配置文件的相关知识,包括其作用、配置方法以及注意事项。 Maven 构建配置…

作者头像 李华