选择客栈

分析

如果枚举左右端点复杂度的下界为 。那么只能枚举一个端点,那么对于另一个端点,我们只关心这两个端点中间有没有最低消费不大于 的。如果我们从左向右扫描,我们一定希望这个点越靠右越好,因为这可以影响更多的点对。对于每一个颜色记录上一个同颜色在哪里。那么只需要最小值点出现在 的右边,那么就可以更新答案,否则只能继承上一个节点的答案。时间复杂度为

代码

#include<bits/stdc++.h>
using namespace std;
#define LL long long
const int N = 2e5+100;
int c[N],val[N],cnt[N],last[N],tot[N],n,k,p,R;
LL ans = 0;
int main() {
    scanf("%d%d%d",&n,&k,&p);
    for(int i = 1;i <= n;i++) {
        scanf("%d%d",&c[i],&val[i]);
    } 
    for(int i = 1;i <= n;i++) {
        if(val[i] <= p) R = i;
        if(R >= last[c[i]]) tot[c[i]] = cnt[c[i]];
        last[c[i]] = i;
        ans += tot[c[i]];
        cnt[c[i]]++;
    }
    cout << ans << endl;
    return 0;
}
全部评论

相关推荐

昨天 22:55
已编辑
叮咚买菜
牛客吹哨人:建议细说...哨哥晚点统一更新到黑名单:不要重蹈覆辙!25届毁意向毁约裁员黑名单https://www.nowcoder.com/discuss/1317104
叮咚买菜稳定性 10人发布 投递叮咚买菜等公司10个岗位 >
点赞 评论 收藏
分享
点赞 评论 收藏
分享
2 1 评论
分享
牛客网
牛客企业服务