leetcode 3740. 三个相等元素之间的最小距离 I 简单

给你一个整数数组 nums

如果满足 nums[i] == nums[j] == nums[k],且 (i, j, k) 是 3 个 不同 下标,那么三元组 (i, j, k) 被称为 有效三元组

有效三元组距离 被定义为 abs(i - j) + abs(j - k) + abs(k - i),其中 abs(x) 表示 x绝对值

返回一个整数,表示 有效三元组最小 可能距离。如果不存在 有效三元组 ,返回 -1

示例 1:

输入: nums = [1,2,1,1,3]

输出: 6

解释:

最小距离对应的有效三元组是 (0, 2, 3)

(0, 2, 3) 是一个有效三元组,因为 nums[0] == nums[2] == nums[3] == 1。它的距离为 abs(0 - 2) + abs(2 - 3) + abs(3 - 0) = 2 + 1 + 3 = 6

示例 2:

输入: nums = [1,1,2,3,2,1,2]

输出: 8

解释:

最小距离对应的有效三元组是 (2, 4, 6)

(2, 4, 6) 是一个有效三元组,因为 nums[2] == nums[4] == nums[6] == 2。它的距离为 abs(2 - 4) + abs(4 - 6) + abs(6 - 2) = 2 + 2 + 4 = 8

示例 3:

输入: nums = [1]

输出: -1

解释:

不存在有效三元组,因此答案为 -1。

提示:

  • 1 <= n == nums.length <= 100
  • 1 <= nums[i] <= n

分析:用一个 vector 记录每个数字出现的位置,当一个数次出现次数大于等于 3 时,计算最后三个出现位置的距离和即可。

cpp 复制代码
class Solution {
public:
    int minimumDistance(vector<int>& nums) {
        int n=nums.size(),ans=1000;
        vector<vector<int>>index(n+5);
        for(int i=0;i<n;++i)
        {
            index[nums[i]].push_back(i);
            if(index[nums[i]].size()>=3)
            {
                ans=min(ans,2*(index[nums[i]][index[nums[i]].size()-1]-index[nums[i]][index[nums[i]].size()-3]));
            }
        }
        return ans==1000?-1:ans;;
    }
};
相关推荐
木井巳21 小时前
【递归算法】单词搜索
java·算法·leetcode·决策树·深度优先
Chase_______1 天前
LeetCode 2461 & 1423:定长滑窗变体精讲,从 HashMap 判重到正难则反的转化技巧
算法·leetcode·职场和发展
sheeta19981 天前
LeetCode 每日一题笔记 日期:2026.05.07 题目:3660. 找到所有可以到达的最大值
笔记·算法·leetcode
Hesionberger1 天前
LeetCode79:单词搜索DFS回溯详解
java·开发语言·c++·python·算法·leetcode·c#
米粒11 天前
力扣算法刷题 Day 62 最短路算法
算法·leetcode·职场和发展
小雅痞1 天前
[Java][Leetcode hard] 30. 串联所有单词的子串
java·leetcode
khalil10201 天前
代码随想录算法训练营Day-43 动态规划10 | 300.最长递增子序列、674. 最长连续递增序列、718. 最长重复子数组
数据结构·c++·算法·leetcode·动态规划·子序列问题
风筝在晴天搁浅1 天前
字节/蚂蚁/美团/拼多多 LeetCode 165.比较版本号
java·leetcode
悲伤小伞1 天前
LeetCode 热题 100_3-128. 最长连续序列
c++·算法·leetcode·哈希算法
m0_629494731 天前
LeetCode 热题 100-----21.搜索二维矩阵 II
数据结构·算法·leetcode