2025.12.09 力扣每日一题

3583.统计特殊三元组

简单做法溢出了,题目题解里的做法好!

cpp 复制代码
class Solution {
public:
    int specialTriplets(vector<int>& nums) {
        //定义取模常量
        const int MOD = 1000000007;
        //初始化后缀哈希表,统计【整个数组中】每个数值出现的次数
        //初始化时,suf包含所有元素,代表j还没开始遍历,所有元素都在j右侧
        unordered_map<int, int> suf;
        for (int x : nums) {
            suf[x]++;//遍历数组,每个数值x的计数+1
        }
        //初始化答案变量,long long防止溢出
        long long ans = 0;
        //初始化前缀哈希表pre:统计【j左侧(0~j-1】每个数值的出现次数,初始为空
        unordered_map<int, int> pre;
        //遍历数组,当前遍历的元素x就是nums[j](j为中间下标)
        for (int x : nums) {
            //关键:把当前x从suf中减1
            //因为当前x是nums[j],j的位置已经确定,它不属于「j右侧的元素」了,所以要从后缀中移除
            suf[x]--;
            //核心计算:以当前j为中间点的三元组数量 = 左边符合条件的数量 × 右边符合条件的数量
            //pre[x*2]:j左侧(0~j-1)中值为x*2的元素个数(即满足nums[i]=2*nums[j]的i的数量)
            //suf[x*2]:j右侧(j+1~n-1)中值为x*2的元素个数(即满足nums[k]=2*nums[j]的k的数量)
            //LL:强制转为long long,避免int相乘溢出
            ans += 1LL * pre[x * 2] * suf[x * 2];
            // 把当前x加入前缀哈希表pre
            //因为遍历完当前j后,下一个j'会在当前j的右侧,当前j就属于「j'左侧的元素」了
            pre[x]++;
        }
        //返回取余结果
        return ans % MOD;
    }
};
相关推荐
20130924162714 小时前
1968年 Hart, Nilsson, Raphael 《最小成本路径启发式确定的形式基础》A* 算法深度研究报告
人工智能·算法
如何原谅奋力过但无声14 小时前
【力扣-Python-滑动窗口经典题】567.字符串的排列 | 424.替换后的最长重复字符 | 76.最小覆盖子串
算法·leetcode
玄冥剑尊15 小时前
贪心算法进阶
算法·贪心算法
玄冥剑尊15 小时前
贪心算法深化 I
算法·贪心算法
52Hz11815 小时前
力扣73.矩阵置零、54.螺旋矩阵、48.旋转图像
python·算法·leetcode·矩阵
BHXDML15 小时前
第一章:线性回归& 逻辑回归
算法·逻辑回归·线性回归
iAkuya16 小时前
(leetcode)力扣100 二叉搜索树种第K小的元素(中序遍历||记录子树的节点数)
算法·leetcode·职场和发展
-To be number.wan16 小时前
B 树 vs B+ 树:为什么 MySQL 用 B+ 树,而不是 B 树?
数据结构
杨间17 小时前
《排序算法全解析:从基础到优化,一文吃透八大排序!》
c语言·数据结构·排序算法
Remember_99317 小时前
【LeetCode精选算法】滑动窗口专题二
java·开发语言·数据结构·算法·leetcode