每日算法一练:剑指offer——数组篇(6)
1.点名
某班级 n 位同学的学号为 0 ~ n-1。点名结果记录于升序数组 records。假定仅有一位同学缺席,请返回他的学号。
示例 1:
输入: records = [0,1,2,3,5] 输出: 4
示例 2:
输入: records = [0, 1, 2, 3, 4, 5, 6, 8] 输出: 7
提示:
1 <= records.length <= 10000
1.1二分法查找
这是一个缺失数问题,在给定的升序数组 records 中找出缺席同学的学号。数组 records 是由班级同学的学号组成的,其中学号从 0 开始,逐个递增,仅有一位同学缺席。要找出缺席的学号,我们可以借助 二分查找 的方法快速定位缺失位置。
解题思路
因为记录是升序的学号列表,仅有一位学号缺失,可以推断:
- 如果数组中没有缺失数字,那么
records[i]应等于i(即每个索引位置的值与其索引相等)。 - 如果某个数字缺失,则从缺失位置开始,数组中的元素不再满足
records[i] = i关系,而是比其索引值大 1。因此,我们可以利用这一规律进行查找。
算法解析
使用二分查找的方式,我们可以在对数时间复杂度 O(log n) 下找到缺失的学号:
- 初始化左右指针:将
i设为0(左指针),j设为records.length - 1(右指针),用于二分查找。 - 循环查找:在
i <= j的条件下,不断收缩查找范围。- 计算中间位置
m = (i + j) / 2。 - 检查
records[m]的值:- 如果
records[m] == m:说明前面没有缺失元素(当前索引m位置的值是正确的),所以缺失的学号在右半部分。将i设为m + 1,向右搜索。 - 如果
records[m] != m:说明缺失学号在左半部分(从当前m位置开始有不匹配的情况)。将j设为m - 1,向左搜索。
- 如果
- 计算中间位置
- 结束循环:当
i大于j时,循环结束,缺失的学号即为i。
最终,i 的位置就是缺失学号的位置。
复杂度分析
- 时间复杂度:二分查找使得时间复杂度为
O(log n),适用于数据规模较大的情况。 - 空间复杂度:仅使用常数级别的额外空间,空间复杂度为
O(1)。
代码示例:
class Solution {public int takeAttendance(int[] records) {// 初始化左右指针int i = 0, j = records.length - 1;// 使用二分查找寻找缺失的学号while(i <= j) {// 计算中间位置 mint m = (i + j) / 2;// 判断中间位置 m 是否与学号对应if(records[m] == m) {// 如果 records[m] == m,说明左侧都正常匹配,缺失学号在右侧i = m + 1; // 将左指针移到右半部分} else {// 如果 records[m] != m,说明缺失学号在左半部分j = m - 1; // 将右指针移到左半部分}}// 最终 i 的位置即为缺失的学号return i;}
}
2.查找总价值为目标值的两个商品
购物车内的商品价格按照升序记录于数组 price。请在购物车中找到两个商品的价格总和刚好是 target。若存在多种情况,返回任一结果即可。
示例 1:
输入:price = [3, 9, 12, 15], target = 18 输出:[3,15] 或者 [15,3]
示例 2:
输入:price = [8, 21, 27, 34, 52, 66], target = 61 输出:[27,34] 或者 [34,27]
提示:
1 <= price.length <= 10^51 <= price[i] <= 10^61 <= target <= 2*10^6
2.1双指针检索
这是一个典型的双指针问题,因为数组 price 已经是升序排列,所以可以使用双指针快速查找两个数的和为 target 的组合。下面是解题思路、算法流程及复杂度分析。
解题思路
-
双指针:从数组的两端开始,逐步缩小范围,利用排序数组的特性进行查找。
- 若两个指针指向的元素之和小于
target,则需要更大的和,因此将左指针右移。 - 若和大于
target,则需要更小的和,因此将右指针左移。 - 当和等于
target时,找到解。
- 若两个指针指向的元素之和小于
-
提前返回:找到符合条件的两个数后,立即返回结果数组
[price[i], price[j]],这样可以保证时间效率。
算法解析
- 初始化:定义两个指针
i和j,分别指向数组的首尾位置。 - 循环条件:在
i < j的条件下进行迭代:- 计算
price[i] + price[j]的和s。 - 比较
s和target:- 如果
s == target,返回[price[i], price[j]]。 - 如果
s < target,左指针i右移,增加和的值。 - 如果
s > target,右指针j左移,减小和的值。
- 如果
- 计算
- 返回结果:若循环结束仍未找到,则返回空数组
[]。
复杂度分析
- 时间复杂度:
O(N),其中N为数组price的长度。双指针仅需线性遍历一次数组。 - 空间复杂度:
O(1),仅使用了常数级的额外空间。
代码示例:
class Solution {public int[] twoSum(int[] price, int target) {// 初始化左右指针int i = 0, j = price.length - 1;// 使用双指针查找两个和为 target 的数while (i < j) {// 计算当前左右指针指向元素的和int s = price[i] + price[j];// 判断当前和 s 是否等于目标 targetif (s < target) {// 若 s 小于 target,说明和偏小,需要增大和// 将左指针右移i++;} else if (s > target) {// 若 s 大于 target,说明和偏大,需要减小和// 将右指针左移j--;} else {// 若 s 等于 target,找到符合条件的组合,立即返回return new int[] { price[i], price[j] };}}// 若未找到符合条件的组合,返回空数组return new int[0];}
}
3.文件组合
待传输文件被切分成多个部分,按照原排列顺序,每部分文件编号均为一个 正整数(至少含有两个文件)。传输要求为:连续文件编号总和为接收方指定数字 target 的所有文件。请返回所有符合该要求的文件传输组合列表。
注意,返回时需遵循以下规则:
- 每种组合按照文件编号 升序 排列;
- 不同组合按照第一个文件编号 升序 排列。
示例 1:
输入:target = 12 输出:[[3, 4, 5]] 解释:在上述示例中,存在一个连续正整数序列的和为 12,为 [3, 4, 5]。
示例 2:
输入:target = 18 输出:[[3,4,5,6],[5,6,7]] 解释:在上述示例中,存在两个连续正整数序列的和分别为 18,分别为 [3, 4, 5, 6] 和 [5, 6, 7]。
提示:
1 <= target <= 10^5
3.1滑动窗口
这是一个寻找连续正整数序列的和等于指定目标值 target 的问题。我们可以使用双指针滑动窗口的方法来高效地查找所有符合条件的组合。下面是解题思路、算法流程和复杂度分析。
解题思路
- 双指针法:使用两个指针
i和j来表示当前正在考虑的连续正整数的起始和结束位置。 - 序列和的计算:维护一个当前和
s,初始为3(即1 + 2),表示i=1和j=2的和。 - 遍历和调整:
- 如果当前和
s等于目标target,则记录下当前的连续整数序列。 - 如果当前和
s大于或等于目标target,则通过移动左指针i来减小和。 - 如果当前和
s小于目标target,则通过移动右指针j来增大和。
- 如果当前和
算法流程
-
初始化:
i为1,表示当前序列的起始位置。j为2,表示当前序列的结束位置。s为3,即i和j所指元素的和。- 使用一个列表
res来存储符合条件的组合。
-
双指针循环:
- 当
i小于j时进行循环:- 如果
s等于target,记录下从i到j的连续整数。 - 如果
s大于或等于target,将s减去i并将i右移。 - 如果
s小于target,将j右移,并更新s。
- 如果
- 当
-
返回结果:
- 将列表
res转换为二维数组返回。
- 将列表
复杂度分析
- 时间复杂度:
O(N),其中N是目标target的值。双指针会遍历连续的正整数并调整,整体复杂度为线性。 - 空间复杂度:
O(M),其中M是存储符合条件组合的个数。由于使用了额外的列表来存储结果,空间复杂度为线性。
import java.util.ArrayList;
import java.util.List;class Solution {public int[][] fileCombination(int target) {// 初始化双指针int i = 1, j = 2, s = 3; // s 为当前连续正整数和List<int[]> res = new ArrayList<>(); // 存储结果// 双指针查找while (i < j) {if (s == target) {// 找到符合条件的组合,记录下当前的连续正整数int[] ans = new int[j - i + 1];for (int k = i; k <= j; k++)ans[k - i] = k; // 填充组合res.add(ans); // 添加到结果列表}// 调整指针if (s >= target) {s -= i; // 减去左边的数字i++; // 左指针右移} else {j++; // 右指针右移s += j; // 增加右边的数字}}// 返回结果数组return res.toArray(new int[0][]);}
}
相关文章:
每日算法一练:剑指offer——数组篇(6)
1.点名 某班级 n 位同学的学号为 0 ~ n-1。点名结果记录于升序数组 records。假定仅有一位同学缺席,请返回他的学号。 示例 1: 输入: records [0,1,2,3,5] 输出: 4示例 2: 输入: records [0, 1, 2, 3, 4, 5, 6, 8] 输出: 7提示: 1 < records.le…...
【环境搭建】Apache ZooKeeper 3.8.4 Stable
软件环境 Ubuntu 20.04 、OpenJDK 11 OpenJDK 11(如果已经安装,可以跳过这一步) 安装OpenJDK 11: $ sudo apt-get update$ sudo apt-get install -y openjdk-11-jdk 设置 JAVA_HOME 环境变量: $ sudo gedit ~/.bash…...
算法练习——双指针
前言:大佬写博客给别人看,菜鸟写博客给自己看,我是菜鸟。 学前须知(对自己):这里的指针不一定指地址!也可能是数组下标。 1:移动零(双指针) 题目要求: 解题思路&#x…...
vue中el-table显示文本过长提示
1.el-table设置轻提示:show-overflow-tooltip“true“,改变轻提示宽度...
JS 字符串拼接并去重
1、includes 循环数组将某个字段拼接成新的字符串并去重(数组里面包含的一个对象,或者其他都OK) // 定义一个数组 let arr[.......] // 定义拼接的字符串 let a //循环数组将里面某个字段拼接在一起并去重 arr.forEach(item > {if(!a.in…...
opencv 图像预处理
图像预处理 在计算机视觉和图像处理领域,图像预处理是一个重要的步骤,它能够提高后续处理(如特征提取、目标检测等)的准确性和效率。OpenCV 提供了许多图像预处理的函数和方法,以下是一些常见的图像预处理操作&…...
SAP B1 功能模块字段介绍 - 价格清单(下)
目录 背景 五、业务伙伴的特殊价格 1. 单据逻辑功能 2. 部分字段解释 3. 操作流程 3.1 时间相关 3.2 数量相关 4. 实例 六、复制特殊价格到选择标准 1. 单据逻辑功能 2. 部分字段解释 七、全局更新特殊价格 编辑 1. 单据逻辑功能 2. 部分字段解释 八、价格更…...
传智杯 第六届-复赛-D
题目描述: 小红定义两个字符串同构,当且仅当对于i∈[1,n],b[i]−a[i]i∈[1,n],b[i]-a[i]i∈[1,n],b[i]−a[i]是定值。例如,"bacd"和"edfg"是同构的。 现在小红拿到了一个长度为n的字符串a,她想知道&a…...
Java - 数组实现大顶堆
题目描述 实现思路 要实现一个堆,我们首先要了解堆的概念。 堆是一种完全二叉树,分为大顶堆和小顶堆。 大顶堆:每个节点的值都大于或等于其子节点的值。 小顶堆:每个节点的值都小于或等于其子节点的值。 完全二叉树ÿ…...
ifuse挂载后,在python代码中访问iOS沙盒目录获取app日志
上一次使用pymobiledevice3,在python代码中访问app的沙盒目录并分析业务日志,在使用过程中发现,在获取app日志的时候速度很慢,执行时间很长,需要30-61秒,所以这次尝试使用libimobiledevic和ifuse࿰…...
Windows WSL环境下安装 pytorch +ROCM 支持AMD显卡
官方文档:Install PyTorch for ROCm — Use ROCm on Radeon GPUs 一、操作系统及驱动 windows 下安装WSL 环境( windows subsystem for Linux), 安装ubuntu 22.04环境。 安装 rocm 软件包: sudo apt update wget https://repo.radeon.com/amdgpu-insta…...
uniapp中skymap.html(8100端口)提示未登录的排查与解决方法
问题: 目前账号已经登录,uniapp的其他端口均可以访问到数据,唯独skymap.html中的8100会提示未登录。(8100是后端网关gateway端口) 分析: 在 skymap.html 中遇到未登录提示的问题,通常是由于该…...
训练模型时梯度出现NAN或者INF(禁用amp的不同level)
判断参数梯度位nan或inf的代码: for name, param in model.named_parameters():if param.grad is not None:if torch.isnan(param.grad).any() or torch.isinf(param.grad).any():print(f"grad layer [{name}] is NaN or Inf") 首先来说可能得原因&…...
Maven核心概念
一、项目对象模型(POM) 1. 定义 POM(Project Object Model)是 Maven 项目的核心配置文件,它以 XML 格式描述了项目的基本信息、项目依赖、构建配置等。可以说,POM 是 Maven 理解和处理项目的基础。 2. 基…...
Sonatype Nexus 部署手册
文章目录 一、前言二、软件环境2.1 版本变更:2.1.1 变更存储的原因2.2.2 H2作为存储的注意点 三、资源配置四、开始部署4.1 部署jdk174.2 离线部署nexus4.2.1 下载4.2.2 部署1. 上传到服务器2. 解压3. 添加用户4. 修改启动参数5. 迁移sonatype-work ,并授…...
TLV320AIC3104IRHBR 数据手册 一款低功耗立体声音频编解码器 立体声耳机放大器芯片麦克风
TLV320AIC3104 是一款低功耗立体声音频编解码器,具有立体声耳机放大器以及在单端或全差分配置下可编程的多个输入和输出。该器件包括基于寄存器的全面电源控制,可实现立体声 48kHz DAC 回放,在 3.3V 模拟电源电压下的功耗低至 14mW࿰…...
(8)结构体、共用体和枚举类型数据
1. 结构体、共用体的定义及区别,typedef 定义别名 结构体的定义 结构体是一种用户自定义的数据类型,它可以将不同类型的数据组合在一起。例如,定义一个表示学生信息的结构体: // 定义结构体类型 struct Student struct Student {char name[20];int age;float score; };共…...
Jedis操作和springboot整合redis
Jedis-springboot整合redis Jedis 引入jedis依赖 注意事项 测试相关数据类型 Key String List set hash zset 案例 spring boot整合redis 引入相关依赖 在application.properties中配置redis 配置 创建redis配置类 创建测试类 Jedis 引入jedis依赖 <depen…...
基于AI大模型的复杂扫描件PDF信息提取与规整
前言 场景大致是会上传一个几十页的扫描件PDF,让AI在当中找出我需要的字段,本文会隐去具体行业信息和具体的AI提示词内容,只分享技术相关内容,请见谅。 AI模型选择 针对我们行业的使用场景,我主要测试了GPT、Claude以…...
为什么https先非对称加密,然后对称加密?
HTTPS之所以先使用非对称加密,然后在对称加密,主要是基于两者在加密效率与安全性方面的特性考虑。 首先,非对称加密具有极高的安全性,因为它使用了公钥和私钥这一对密钥。公钥是公开的,任何人都可以使用它来加密数据&…...
MongoDB学习和应用(高效的非关系型数据库)
一丶 MongoDB简介 对于社交类软件的功能,我们需要对它的功能特点进行分析: 数据量会随着用户数增大而增大读多写少价值较低非好友看不到其动态信息地理位置的查询… 针对以上特点进行分析各大存储工具: mysql:关系型数据库&am…...
【解密LSTM、GRU如何解决传统RNN梯度消失问题】
解密LSTM与GRU:如何让RNN变得更聪明? 在深度学习的世界里,循环神经网络(RNN)以其卓越的序列数据处理能力广泛应用于自然语言处理、时间序列预测等领域。然而,传统RNN存在的一个严重问题——梯度消失&#…...
【CSS position 属性】static、relative、fixed、absolute 、sticky详细介绍,多层嵌套定位示例
文章目录 ★ position 的五种类型及基本用法 ★ 一、position 属性概述 二、position 的五种类型详解(初学者版) 1. static(默认值) 2. relative(相对定位) 3. absolute(绝对定位) 4. fixed(固定定位) 5. sticky(粘性定位) 三、定位元素的层级关系(z-i…...
拉力测试cuda pytorch 把 4070显卡拉满
import torch import timedef stress_test_gpu(matrix_size16384, duration300):"""对GPU进行压力测试,通过持续的矩阵乘法来最大化GPU利用率参数:matrix_size: 矩阵维度大小,增大可提高计算复杂度duration: 测试持续时间(秒&…...
【JavaSE】绘图与事件入门学习笔记
-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角,以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向,距离坐标原点x个像素;第二个是y坐标,表示当前位置为垂直方向,距离坐标原点y个像素。 坐标体系-像素 …...
rnn判断string中第一次出现a的下标
# coding:utf8 import torch import torch.nn as nn import numpy as np import random import json""" 基于pytorch的网络编写 实现一个RNN网络完成多分类任务 判断字符 a 第一次出现在字符串中的位置 """class TorchModel(nn.Module):def __in…...
return this;返回的是谁
一个审批系统的示例来演示责任链模式的实现。假设公司需要处理不同金额的采购申请,不同级别的经理有不同的审批权限: // 抽象处理者:审批者 abstract class Approver {protected Approver successor; // 下一个处理者// 设置下一个处理者pub…...
[大语言模型]在个人电脑上部署ollama 并进行管理,最后配置AI程序开发助手.
ollama官网: 下载 https://ollama.com/ 安装 查看可以使用的模型 https://ollama.com/search 例如 https://ollama.com/library/deepseek-r1/tags # deepseek-r1:7bollama pull deepseek-r1:7b改token数量为409622 16384 ollama命令说明 ollama serve #:…...
作为测试我们应该关注redis哪些方面
1、功能测试 数据结构操作:验证字符串、列表、哈希、集合和有序的基本操作是否正确 持久化:测试aof和aof持久化机制,确保数据在开启后正确恢复。 事务:检查事务的原子性和回滚机制。 发布订阅:确保消息正确传递。 2、性…...
嵌入式常见 CPU 架构
架构类型架构厂商芯片厂商典型芯片特点与应用场景PICRISC (8/16 位)MicrochipMicrochipPIC16F877A、PIC18F4550简化指令集,单周期执行;低功耗、CIP 独立外设;用于家电、小电机控制、安防面板等嵌入式场景8051CISC (8 位)Intel(原始…...
