Day12力扣打卡

打卡记录

找出满足差值条件的下标 II(双指针+维护最大最小)

链接

采用双指针保留间隔 indexDifference 进行遍历,求出慢指针对应一路遍历过来的最大值和最小值。

cpp 复制代码
class Solution {
public:
    vector<int> findIndices(vector<int>& nums, int indexDifference, int valueDifference) {
        int min_idx = 0, max_idx = 0;
        for (int i = indexDifference; i < nums.size(); ++i) {
            int j = i - indexDifference;
            if (nums[j] > nums[max_idx]) max_idx = j;
            if (nums[j] < nums[min_idx]) min_idx = j;
            if (nums[i] - nums[min_idx] >= valueDifference) return {min_idx, i}; 
            if (nums[max_idx] - nums[i] >= valueDifference) return {i, max_idx};
        }
        return {-1, -1};
    }
};
相关推荐
ALex_zry2 小时前
C++ ORM与数据库访问层设计:Repository模式实战
开发语言·数据库·c++
RFdragon4 小时前
分享本周所学——三维重建算法3D Gaussian Splatting(3DGS)
人工智能·线性代数·算法·机器学习·计算机视觉·矩阵·paddlepaddle
浅念-6 小时前
Linux 开发环境与工具链
linux·运维·服务器·数据结构·c++·经验分享
旺仔.2917 小时前
容器适配器:stack栈 、queue队列、priority queue优先级队列、bitset位图 详解
c++
刘景贤8 小时前
C/C++开发环境
开发语言·c++
Zero9 小时前
机器学习微积分--(1)核心思想
人工智能·算法·机器学习
OasisPioneer9 小时前
现代 C++ 全栈教程 - Modern-CPP-Full-Stack-Tutorial
开发语言·c++·开源·github
有Li9 小时前
一种病理学内容感知变速率学习图像压缩框架 (PathoLIC)/文献速递-多模态应用技术
人工智能·深度学习·算法·计算机视觉·医学生
liulilittle10 小时前
XDP to TC : TUN eBPF NAT
c++
x_xbx10 小时前
LeetCode:34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode