C++桶排序算法的应用:存在重复元素 III

题目

给你一个整数数组 nums 和两个整数 indexDiff 和 valueDiff 。
找出满足下述条件的下标对 (i, j):
i != j,
abs(i - j) <= indexDiff
abs(nums[i] - nums[j]) <= valueDiff
如果存在,返回 true ;否则,返回 false 。

示例 1:
输入:nums = [1,2,3,1], indexDiff = 3, valueDiff = 0
输出:true
解释:可以找出 (i, j) = (0, 3) 。
满足下述 3 个条件:
i != j --> 0 != 3
abs(i - j) <= indexDiff --> abs(0 - 3) <= 3
abs(nums[i] - nums[j]) <= valueDiff --> abs(1 - 1) <= 0
示例 2:
输入:nums = [1,5,9,1,5,9], indexDiff = 2, valueDiff = 3
输出:false
解释:尝试所有可能的下标对 (i, j) ,均无法满足这 3 个条件,因此返回 false 。
提示:
2 <= nums.length <= 105
-109 <= nums[i] <= 109
1 <= indexDiff <= nums.length
0 <= valueDiff <= 109

滑动窗口+有序集合

代码

class Solution {
public:
bool containsNearbyAlmostDuplicate(vector& nums, int indexDiff, int valueDiff) {
std::multiset setHas;
for (int i = 0; i < nums.size(); i++)
{
const int iDelIndex = i - indexDiff - 1;
if (iDelIndex >= 0)
{
auto it = setHas.find(nums[iDelIndex]);
setHas.erase(it);
}
auto it1 = setHas.lower_bound(nums[i] - valueDiff);
auto it2 = setHas.upper_bound(nums[i] + valueDiff);
if (it1 != it2)
{
return true;
}
setHas.emplace(nums[i]);
}
return false;
}
};

分析

如果(i,j)符合,则(j,i)也符合。所以可以只考虑i<j,不考虑i>j。题意明确表示i!=j。所以只需要考虑i<j。用有序集合表示滑动窗口nums[max(0,j-k),j]。其实用set就可以了,multiset可以少一个判断:如果存在重复值直接返回true。

排序

来表示滑动窗口。设置的大小为valueDiff+1,如果2个数在同一个中说明符合。如果符合直接返回,所以一个不会存在两个像素。可以用哈希映射来表示。如果不在一个,还要比较是否和前一个或后一符合条件。

代码

class Solution {
public:
bool containsNearbyAlmostDuplicate(vector& nums, int k, int t) {
unordered_map<int, int> mp;
int n = nums.size();
for (int i = 0; i < n; i++)
{
const int curValue = nums[i];
int inx = GetBucketIndex(curValue, t + 1);
if (mp.count(inx))
{
return true;
}
if (mp.count(inx - 1) && (abs(curValue - mp[inx - 1]) <= t))
{
return true;
}
if (mp.count(inx + 1) && (abs(curValue - mp[inx + 1]) <= t))
{
return true;
}
mp[inx] = curValue;
if (i>= k)
{
const int iEraseIndex = GetBucketIndex(nums[i - k ],t+1);
mp.erase(iEraseIndex);
}
}
return false;
}
int GetBucketIndex(int value, int iBuckCap)
{
return value >= 0 ? (value / iBuckCap) : ((value + 1) / iBuckCap - 1);
}
};

其它

视频课程

要是你认为本篇难道较大,不好入手,推荐你先学习基础算法的课程,我已完成部分,余下部分持续更新中,就在CSDN学院。
https://edu.csdn.net/course/detail/38771

C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

测试环境

操作系统:win7 开发环境: VS2019 **C+

+17**

相关下载

如果你想观其大略,建设下载《闻缺陷则喜算法册》doc版
https://download.csdn.net/download/he_zhidan/88348653

博主想队大家说的话
墨家名称的来源:有所得以墨记之。
闻缺陷则喜的来由:早发现,早修改问题,成本更低
程序是龙,算法是睛


http://www.niftyadmin.cn/n/5093459.html

相关文章

【背景调查】企业HR自主操作背调都有哪些“坑”?这份避坑指南请收好!

近期&#xff0c;有一则招聘相关的信息被频繁提及&#xff1a;互联网大厂初试简历造假率超过了30%&#xff01; 职场失信&#xff0c;可见一斑。 泛滥的简历造假似乎正逐渐成为一种社会现象&#xff0c;而其中造假最多的是工作履历&#xff0c;其次是学历。 求职者为提高职场…

安捷伦N8482A射频传感器6GHz

安捷伦N8482A射频传感器 N8482A 是 Agilent 使用的 6 GHz 0.1 瓦射频传感器。电子测试设备传感器测量波形的功率&#xff0c;例如多音和调制射频 (RF) 波形。传感器使用二极管检测器收集高度精确的调制测量值。 用于存储校准系数的 EEPROM 消除了手动输入 100 kHz 至 6 GHz 的宽…

2022 年中职组“ 网络安全 ”赛项-web加固阶段题目

前言 大家好&#xff0c;本章节我将复现一次web加固阶段的操作&#xff0c;给大家看看该怎么操作和截图的具体事项&#xff0c;懂的大佬可以在评论区留言改进&#xff0c;感谢大家的支持&#xff01;接下来就跟随我的步伐一起来操作吧&#xff01; 阶段题目概览 环境搭建 底层…

阿里云新加坡主机服务器选择

阿里云新加坡主机有哪些选择&#xff1f;可以选择云服务器ECS或轻量应用服务器&#xff0c;都有新加坡地域可以选择&#xff0c;东南亚地区可以选择新加坡、韩国首尔、日本东京等地域&#xff0c;阿里云新加坡主机测试IP地址&#xff1a;161.117.118.93 可以测试下本地到新加坡…

08-网络篇-一步步完成网络通信

上面的章节描述了Tcp/ip四层网络模型&#xff0c;并介绍了每一层的常见的协议&#xff0c;本章来讨论一下&#xff0c;一个主机是怎样与外网中的另一个主机通信。 假如网络结构如下 上图是一个典型的网络结构图&#xff0c;若主机1是电脑&#xff0c;主机4是服务器&#xff0c;…

橙河网络:国外答题问卷赚钱可靠吗?

大家好&#xff0c;我是橙河网络&#xff0c;今天聊一聊国外答题问卷赚钱可靠吗&#xff1f;这几年&#xff0c;很多人都了解到海外问卷调查这个项目&#xff0c;这是一个类似网络搬砖的项目&#xff0c;可以自己做&#xff0c;现实中也有很多老板选择组建工作室运营这个项目。…

精密空调别再这样管理了,太麻烦啦!

在现代生活中&#xff0c;空调系统已经成为不可或缺的一部分&#xff0c;特别是在高温季节。然而&#xff0c;空调系统的有效性和效率对于节能、环保和用户舒适性至关重要。为了更好地满足这些需求&#xff0c;精密空调监控系统应运而生。 精密空调监控系统结合了先进的技术&am…

1.DApp-做一个DApp需要学习什么

题记 以下是做一个dapp需要学习的知识。 具体内容 具体内容如下&#xff1a; 区块链基础知识&#xff1a;了解区块链的基本概念、工作原理以及不同区块链平台的特性&#xff0c;如以太坊、EOS等。 智能合约开发&#xff1a;掌握智能合约的编写和部署&#xff0c;使用Solidity…