《剑指 Offer》专项突破版 - 面试题 68 : 查找插入位置/ 69 : 山峰数组的顶部(C++ 实现)

本文主要是介绍《剑指 Offer》专项突破版 - 面试题 68 : 查找插入位置/ 69 : 山峰数组的顶部(C++ 实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

面试题 68 : 查找插入位置

面试题 69 : 山峰数组的顶部


 


面试题 68 : 查找插入位置

题目

输入一个排序的整数数组 nums 和一个目标指 t,如果数组 nums 中包含 t,则返回 t 在数组中的下标;如果数组 nums 中不包含 t,则返回将 t 按顺序插入数组 nums 中的下标。假设数组中没有相同的数字。例如,输入数组 nums 为 [1, 3, 6, 8],如果目标值 t 为 3,则输出 1;如果 t 为 5,则返回 2。

分析

首先考虑如果目标值 t 不在数组中时它应该被插入哪个位置。由于数组是排序的,因此它应该排在所有比它小的数字的后面。也就是说,它的插入位置满足两个条件:一是该位置上的数字大于 t,二是该位置的前一个数字小于 t(总结下来就是:数组中第一个大于 t 的数字的位置)。例如,当数组为 [1, 3, 6, 8],目标值为 5,它将被插入下标为 2 的位置,该位置当前的值为 6,大于目标值,该位置的前一个值是 3,小于目标值。

当数组中包含目标值时,返回它在数组中的位置。

综上所述,即查找数组中第一个大于或等于 t 的数字的位置

代码实现

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

当 while 循环结束(left > right),left 左边的数字都小于 target,right 右边的数字都大于或等于 target,因此 right + 1,即 left 就是第一个大于或等于 target 的数字的位置


面试题 69 : 山峰数组的顶部

题目

符合下列属性的数组 arr 称为山峰数组:

  • arr.length >= 3

  • 存在 i(0 < i < arr.length - 1) 使得:arr[0] < arr[1] < ··· < arr[i - 1] < arr[i] > arr[i + 1] > ··· > arr[arr.length - 1]

给定由整数组成的山峰数组 arr,返回下标 i,即山峰顶部(数组中最大值的位置)。

例如,在数组 [1, 3, 5, 4, 2] 中,最大值是 5,输出它在数组中的下标 2。

分析

不难想到直观的解法来解决这个题目,即逐一扫描整个数组,通过比较就能找出数组中的最大值。显然,这种解法的时间复杂度是 O(n)。这种解法对任意数组都适用,并没有充分利用这个题目的特点,即数组先递增再递减。由于问题是关于在排序数组中查找数字,虽然整个数组并不是排序的,但分成前后两段后每段都分别排序,因此二分查找算法值得一试

山峰数组中的最大值是数组中唯一一个比它左右两边数字都大的数字。位于最大值前面的数字(除第 1 个数字之外)总是比它前一个数字大但比它后一个数字小;位于最大值后面的数字(除最后一个数字之外)总是比它前一个数字小但比它后一个数字大

可以根据山峰数组的这个特点应用二分查找算法。先取出数组中间的数字

  1. 如果这个数字比它前后两个数字都大,那么就找到了数组的最大值

  2. 如果这个数字比它前一个数字大但比后一个数字小,那么这个数字位于数组递增的部分,数组的最大值一定在它的后面,接下来只需要在数组的后半部分查找就可以

  3. 如果这个数字比它前一个数字小但比后一个数字大,那么这个数字位于数组递减的部分,数组的最大值一定在它的前面,接下来只需要在数组的前半部分查找就可以

代码实现

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

注意

  1. 在一个长度为 n 的山峰数组中,由于第 1 个数字和最后一个数字都不可能是最大值,因此初始查找范围为数组下标从 1 到 n - 2 的部分

  2. 如果输入的数组是一个有效的山峰数组,那么 while 循环中一定能找到山峰数组的最大值。只是 C++ 的语法要求函数的每个分支必须有返回值,所以在函数体的最后添加一行返回 -1 的代码。实际上,这一行代码不会被执行

这篇关于《剑指 Offer》专项突破版 - 面试题 68 : 查找插入位置/ 69 : 山峰数组的顶部(C++ 实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/770197

相关文章

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

Java Lettuce 客户端入门到生产的实现步骤

《JavaLettuce客户端入门到生产的实现步骤》本文主要介绍了JavaLettuce客户端入门到生产的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录1 安装依赖MavenGradle2 最小化连接示例3 核心特性速览4 生产环境配置建议5 常见问题

linux ssh如何实现增加访问端口

《linuxssh如何实现增加访问端口》Linux中SSH默认使用22端口,为了增强安全性或满足特定需求,可以通过修改SSH配置来增加或更改SSH访问端口,具体步骤包括修改SSH配置文件、增加或修改... 目录1. 修改 SSH 配置文件2. 增加或修改端口3. 保存并退出编辑器4. 更新防火墙规则使用uf

Java 的ArrayList集合底层实现与最佳实践

《Java的ArrayList集合底层实现与最佳实践》本文主要介绍了Java的ArrayList集合类的核心概念、底层实现、关键成员变量、初始化机制、容量演变、扩容机制、性能分析、核心方法源码解析、... 目录1. 核心概念与底层实现1.1 ArrayList 的本质1.1.1 底层数据结构JDK 1.7

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符