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

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 }

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

感谢大家的三连支持!

http://www.cnnetsun.cn/news/53813.html

相关文章:

  • WaveTools鸣潮120帧解锁与游戏性能优化全攻略
  • 三步学会百度网盘极速下载:告别龟速的终极方案
  • 5大实用技巧:用Calibre-Douban插件智能管理电子书元数据
  • 飞书文档批量导出终极指南:一键解决文档迁移难题
  • Source Han Serif思源宋体:免费开源中文字体专业应用指南
  • DOM Element:深入理解与操作
  • 深度解析 Flutter 路由管理:从原生路由到 AutoRoute 的优雅升级与性能优化
  • Turnitin系统查英文AI率多少为正常?报告显示星号*%怎么办?
  • 暖通净化空调恒温恒湿项目:PLC 与触摸屏上位机程序探秘
  • 第30章 Shell 正则表达式实战:精准匹配字符串、日志与配置项
  • 音视频学习(七十二):视频压缩:分块与预处理
  • AMD Ryzen性能调优:快速掌握处理器调试工具的使用技巧
  • 深蓝词库转换:轻松打通全平台输入法数据壁垒
  • (新卷,200分)- 最小传输时延Ⅱ(Java JS Python)
  • OpenHarmony AI人脸识别与手势控制系统开发指南
  • 新一代空间感知驱动的军工仓库与硐室透明化管控技术研究
  • Sketch MeaXure插件:设计师必备的智能标注工具
  • 强化学习Q-learning求最优策略
  • 你对电脑上的【Fn】熟悉多少
  • 计及N-k安全约束的含光热电站电力系统优化调度模型【IEEE14节点、118节点】附Matlab代码
  • 计及需求响应的粒子群算法求解风能、光伏、柴油机、储能容量优化配置附Matlab代码
  • conda使用详细指南
  • 豆包与DeepSeek底层大模型的深度解析:技术架构、设计理念与生态分野
  • Linux系统中的socket激活:先创建监听端口,后启动程序
  • 从零解决pyproject.toml构建失败的实战指南
  • Redis Lua脚本入门:从零写出你的第一个原子操作
  • 旧机转手不再慌!电子产品信息清除新国标落地,核心技术逻辑全解析
  • 安全体验馆好用供应商
  • 第二章——数据分析场景之Python数据可视化:用Matplotlib与Seaborn绘制洞察之图
  • 【Java毕设全套源码+文档】基于springboot的高校毕业生离校管理系统小程序设计与实现(丰富项目+远程调试+讲解+定制)