剑指offer - 面试题11 旋转数组的最小数字

题目链接:旋转数组的最小数字

第一种:正确写法(num[m]和nums[r]比较)

class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param nums int整型vector * @return int整型*/int minNumberInRotateArray(vector<int>& nums) {// write code hereint l = 0, m = 0, r = nums.size() - 1;while (l < r) { // 将结果框在[l,r]的范围内,因此当l==r时,代表就是结果m = (l + r) / 2; // 此处在l=r-1时要注意死循环,因为循环条件时l < r,如果在l根据m改变时,必须给l赋值m+1,因为直接赋值为m就会导致死循环。(此处只需要注意l=m+1,而r=m是可以的,这是因为(l+r)/2的结果可能等于l,但不可能等于r)if (nums[m] > nums[r]) {l = m + 1; // 说明m是在第一个上升数组中,且m不可能是最小值,所以m这个位置不需要保留,同时为了避免死循环,l=m+1而不是l=m} else if (nums[m] < nums[r]) {r = m; // 说明m是在第二个上升数组中,且m有可能是结果的位置,因此m必须要保留,r=m而不是r=m-1} else {r--; // 此处就是第一次没想到的解法,当nums[m] == nums[r]时,没法确定是第一个还是第二个上升数组,但能确定的是,r这个位置可以不要了,因为有m在保留着结果(m不可能等于r,因为如果m==r的话,说明l==r,那么循环就走不到这里了。为了缩小结果集范围,直接r--就可以了)}}return nums[l];}
};

但是很神奇的是,上面的代码都是和num[r]比较的,但如果像下面这么写,有些用例就是失败的
第二种错误写法:nums[m]和num[l]比较

class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param nums int整型vector * @return int整型*/int minNumberInRotateArray(vector<int>& nums) {// write code hereint l = 0, m = 0, r = nums.size() - 1;while (l < r) {m = (l + r) / 2;if (nums[m] > nums[l]) {l = m + 1;} else if (nums[m] < nums[l]) {r = m;} else {l++;}}return nums[l];}
};

上面的代码表明看起来是对的,但这段代码只能通过部分用例。

因为存在特殊情况,即在旋转0个数字情况下,nums[m]是一定会大于num[l],此时按照上面的代码,l=m+1,l会越加越多,离正确答案nums[0]越来越远了。

因此这就是为什么要按照第一种写法,nums[m]和num[r]进行比较。在旋转0个数字这种特殊情况,nums[m]<num[r]是永远成立的,此时的操作正好是r = m,就不会错过正确答案。
例如[1,0,1,1,1]这个输入,nums[m]和nums[l]比较这个上面的第二种代码就是错误的。
第一轮l=0,r=4,m=2。此时nums[l]==nums[r],因此l++
第二轮l=1,r=4,m=2。此时[l,r]就是[0,1,1,1]这个升序的序列了,就是上面所说的特殊场景,nums[m] > nums[l],按照第二种代码的逻辑,l = m+1,l=3。这样直接就把正确答案跳过去了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/71905.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring源码分析の循环依赖

文章目录 前言一、循环依赖问题二、循环依赖的解决三、整体流程分析 前言 常见的可能存在循环依赖的情况如下&#xff1a; 两个bean中互相持有对方作为自己的属性。   类似于&#xff1a; 两个bean中互相持有对方作为自己的属性&#xff0c;且在构造时就需要传入&#xff1a…

Docker 部署 Jenkins持续集成(CI)工具

[TOC](Docker 部署 Jenkins持续集成(CI)工具) 前言 Jenkins 是一个流行的开源自动化工具&#xff0c;广泛应用于持续集成&#xff08;CI&#xff09;和持续交付&#xff08;CD&#xff09;的环境中。通过 Docker 部署 Jenkins&#xff0c;可以简化安装和配置过程&#xff0c;并…

《Effective Objective-C》阅读笔记(中)

目录 接口与API设计 用前缀避免命名空间冲突 提供“全能初始化方法” 实现description方法 尽量使用不可变对象 使用清晰而协调的命名方式 方法命名 ​编辑类与协议命名 为私有方法名加前缀 理解OC错误模型 理解NSCopying协议 协议与分类 通过委托与数据源协议进行…

C++程序员内功修炼——Linux C/C++编程技术汇总

在软件开发的宏大版图中&#xff0c;C 语言宛如一座巍峨的高山&#xff0c;吸引着无数开发者攀登探索。而 Linux 操作系统&#xff0c;以其开源、稳定、高效的特性&#xff0c;成为了众多开发者钟爱的开发平台。将 C 与 Linux 相结合&#xff0c;就如同为开发者配备了一把无坚不…

数据库索引:缺点与类型全解析

在数据库的世界里&#xff0c;索引就像是一本书的目录&#xff0c;它能帮助我们快速定位到所需的数据&#xff0c;极大地提升查询效率。然而&#xff0c;就如同任何事物都有两面性一样&#xff0c;索引也并非完美无缺。今天&#xff0c;我们就来深入探讨一下索引的缺点以及常见…

【python】提取word\pdf格式内容到txt文件

一、使用pdfminer提取 import os import re from pdfminer.high_level import extract_text import docx2txt import jiebadef read_pdf(file_path):"""读取 PDF 文件内容:param file_path: PDF 文件路径:return: 文件内容文本"""try:text ext…

嵌入式八股文(五)硬件电路篇

一、名词概念 1. 整流和逆变 &#xff08;1&#xff09;整流&#xff1a;整流是将交流电&#xff08;AC&#xff09;转变为直流电&#xff08;DC&#xff09;。常见的整流电路包括单向整流&#xff08;二极管&#xff09;、桥式整流等。 半波整流&#xff1a;只使用交流电的正…

精选案例展 | 智己汽车—全栈可观测驱动智能化运营与成本优化

本案例为“观测先锋 2024 可观测平台创新应用案例大赛”精选案例&#xff0c;同时荣获IT168“2024技术卓越奖评选-年度创新解决方案”奖。 项目背景 近年来&#xff0c;中国汽车行业进入转型升级阶段&#xff0c;智能网联技术成为行业发展的核心。车联网、自动驾驶等技术的加速…

速通HTML

目录 HTML基础 1.快捷键 2.标签 HTML进阶 1.列表 a.无序列表 b.有序列表 c.定义列表 2.表格 a.内容 b.合并单元格 3.表单 a.input标签 b.单选框 c.上传文件 4.下拉菜单 5.文本域标签 6.label标签 7.按钮标签 8.无语义的布局标签div与span 9.字符实体 HTML…

【Python模块】——pymysql

pymysql是python操作mysql的标准库&#xff0c;可以通过pip install快速导入pymysql包操作数据库 使用pymysql操作mysql 简单demo import pymysql connect pymysql.connect(host"localhost",port3306,user"root",password"root",database&quo…

IP离线库助力破解网络反诈难题

毫秒级响应识别异常访问 IP离线库集成全球全量IP地址的详细信息&#xff0c;包括地理地址查询、运营商、经纬度、代理识别等多种维度数据。例如&#xff1a; 当用户账号频繁从北京、越南等多地IP登录时&#xff0c;系统将自动触发风险预警&#xff1b; 检测到访问IP为已知机…

lattice hdl实现spi接口

在lattice工具链中实现SPI接口通常涉及以下步骤: 定义硬件SPI接口的管脚。配置SPI时钟和模式。编写SPI主机或从机的控制逻辑。 展示了如何在Lattice工具链中使用HDL语言(例如Verilog)来配置SPI接口: lattice工程 顶层:spi_slave_top.v `timescale 1ns/ 1ps module spi_…

Spring 循环依赖解析与解决方案

文章目录 1. 什么是循环依赖&#xff1f;1.1 概念解析1.2 示例代码 2. 循环依赖的类型2.1 构造器循环依赖&#xff08;不可解决 ❌&#xff09;2.2 Setter 方式或 Autowired 方式的循环依赖&#xff08;可解决 ✅&#xff09; 3. 解决循环依赖的方式3.1 方式一&#xff1a;使用…

Cesium@1.126.0,创建3D瓦片,修改样式

第一步&#xff1a;添加3D建筑 Cesium.createOsmBuildingsAsync()这是一个异步方法&#xff0c;所以要写在一个异步函数里 创建一个函数 const create3DBuilding async (viewer) > {try {// 添加3D建筑const tileset await Cesium.createOsmBuildingsAsync();viewer.scen…

力扣-贪心-1005 k次取反后最大化的数组和

思路 找到绝对值最大的&#xff0c;然后如果是负数就变成正的&#xff0c;所有数遍历完之后&#xff0c;有两种情况&#xff0c;一种是k已经为0了&#xff0c;不需要再取反了&#xff0c;一种是所有数都为正数&#xff0c;k不为0&#xff0c;此时对绝对值最小的数操作即可 代…

vue2项目打包后js文件过大, 首次加载缓慢

vue2项目打包后js文件过大, 首次加载缓慢 安装插件 npm i compression-webpack-plugin6.1.1 -D配置vue.config.js const CompressionWebpackPlugin require(compression-webpack-plugin)module.exports {configureWebpack: {plugins:[new CompressionWebpackPlugin({filen…

高级SQL技术在Python项目中的应用:ORM与深度性能优化

引言 在现代Python项目开发中,数据库交互远不止是数据的简单存取,它已成为构建高性能、可维护应用的核心瓶颈和关键能力所在。 仅仅依赖基础SQL查询,虽然入门简单,却难以应对日益增长的应用挑战。这些挑战主要体现在以下几个方面: 性能瓶颈: 数据量剧增: 从百万到数十亿乃…

基于 C++ Qt 的 Fluent Design 组件库 QFluentWidgets

简介 QFluentWidgets 是一个基于 Qt 的 Fluent Designer 组件库&#xff0c;内置超过 150 个开箱即用的 Fluent Designer 组件&#xff0c;支持亮暗主题无缝切换和自定义主题色。 编译示例 以 Qt5 为例&#xff08;Qt6 也支持&#xff09;&#xff0c;将 libQFluentWidgets.d…

抖音视频如何下载保存去水印

随着短视频平台的兴起&#xff0c;抖音作为国内最受欢迎的短视频平台之一&#xff0c;吸引了大量用户上传和观看各种创意视频。许多用户在浏览抖音视频时&#xff0c;往往会想要保存一些有趣或精彩的视频片段&#xff0c;但抖音视频通常会有水印&#xff0c;影响观看体验。为了…

React 源码揭秘 | 更新队列

前面几篇遇到updateQueue的时候&#xff0c;我们把它先简单的当成了一个队列处理&#xff0c;这篇我们来详细讨论一下这个更新队列。 有关updateQueue中的部分&#xff0c;可以见源码 UpdateQueue实现 Update对象 我们先来看一下UpdateQueue中的内容&#xff0c;Update对象&…