(枚举)(模拟)(前缀和)(数组模拟哈希)(可二分)1236. 递增三元组

简介: (枚举)(模拟)(前缀和)(数组模拟哈希)(可二分)1236. 递增三元组

题目链接

1236. 递增三元组 - AcWing题库

一些话

int f[N];

memset(f,0,sizeof f)影响不到f[N]

所以尽量不要对f[N]赋值,不要用f[N]操作

流程

//由三重暴力i,j,k因为三重暴力底下是分别用i和j,j和k作比较,想到可以拆成i~j,j ~k 再乘起来,

// 但 n < 1e5,双循环复杂度也还是太高,不过还有更优的方法,

// 即枚举b中元素,求b的第k个元素大于a中元素的个数,和b的第k个元素小于c中元素的个数,然后相乘。可以通过前缀和+哈希或二分来实现

// 前缀和+哈希要先统计a和c的元素个数,然后通过前缀和来得到a和c中小于等于某值的元素个数的数组,

// 然后求b的第k个元素大于a中元素的个数就是这个a中小于等于b[k] -1 的元素个数,即s[b[k] - 1]

//b的第k个元素小于c中元素的个数就是c中元素的个数减去c中小于等于b的第k个元素的个数,即s[N-1] - s[b[i]];

套路

统计数组中小于等于多个某值的元素个数:

       先哈希统计元素个数,然后前缀和

1. for(int i = 0;i < n;i++) cnt[a[i]]++;
2. for(int i = 1;i < N;i++) s[i] += s[i-1] + cnt[i];

ac代码

#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
using namespace std;
const int N = 1e5 + 10;
int a[N],b[N],c[N],cc[N],ca[N],cnt[N],s[N];
int main(){
    int n;
    cin >> n;
    for(int i = 0;i < n;i++) cin >> a[i] , a[i]++;
    for(int i = 0;i < n;i++) cin >> b[i] , b[i]++;
    for(int i = 0;i < n;i++) cin >> c[i] , c[i]++;
    for(int i = 0;i < n;i++) cnt[a[i]]++;
    for(int i = 1;i < N;i++) s[i] += s[i-1] + cnt[i];
    for(int i = 0;i < n;i++) ca[i] = s[b[i]-1];
    memset(s,0,sizeof s);
    memset(cnt,0,sizeof cnt);
    for(int i = 0;i < n;i++) cnt[c[i]]++;
    for(int i = 1;i < N;i++) s[i] += s[i-1] + cnt[i];
    for(int i = 0;i < n;i++) cc[i] = s[N-1] - s[b[i]];
    long long ans = 0;
    for(int i = 0;i < n;i++){
        ans += ca[i] * (long long) cc[i];
    }
    cout << ans << endl;
    return 0;
}
目录
相关文章
|
6月前
【Leetcode 2645】构造有效字符串的最小插入数 —— 动态规划
状态定义:`d[i]`为将前 i 个字符拼凑成若干个 abc 所需要的最小插入数。状态转移方程: 如果` word[i]>word[i−1]`,那么`word[i]`可以和`word[i−1]`在同一组 abc 中,`d[i]=d[i−1]−1` ;否则`word[i]`单独存在于一组 abc 中,`d[i]=d[i−1]+2`
|
6月前
【每日一题Day163】LC2367算术三元组的数目 | 二分查找 哈希表
【每日一题Day163】LC2367算术三元组的数目 | 二分查找 哈希表
30 0
|
6月前
|
存储 Python
处理随机元素来创建数列是一个涉及随机数生成和数列构造的过程
处理随机元素来创建数列是一个涉及随机数生成和数列构造的过程
57 0
|
6月前
|
算法 测试技术 C#
【数学】LeetCode1526: 形成目标数组的子数组最少增加次数
【数学】LeetCode1526: 形成目标数组的子数组最少增加次数
|
6月前
|
存储 算法 Java
数据结构和算法面试题:给定一个整数数组 nums,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
数据结构和算法面试题:给定一个整数数组 nums,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
88 0
|
6月前
leetcode-5894:至少在两个数组中出现的值
leetcode-5894:至少在两个数组中出现的值
47 0
|
6月前
【每日一题Day234】LC1171从链表中删去总和值为零的连续节点 | 链表模拟 哈希表+前缀和
【每日一题Day234】LC1171从链表中删去总和值为零的连续节点 | 链表模拟 哈希表+前缀和
39 0
|
人工智能
前缀和 差分数组编程题集合
前缀和 差分数组编程题集合
图解LeetCode——1798. 你能构造出连续值的最大数目
图解LeetCode——1798. 你能构造出连续值的最大数目
76 0
|
人工智能
(数论)(枚举)(前缀和)1230. K倍区间
(数论)(枚举)(前缀和)1230. K倍区间
87 0