CF1352E Special Permutation(桶排序+前缀和)
Posted zhanglichen
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CF1352E Special Permutation(桶排序+前缀和)相关的知识,希望对你有一定的参考价值。
题意:
给你一个序列,如果有一个数满足序列里的一段子序列的和等于这个数,那么就称这个数为特殊数。
请你计算有多少个特殊数。
题解:
观察数据范围,我们可以构造一个桶记录每个数的出现次数,再枚举所有前缀和统计,用完这个桶就把它清空,时间复杂度O(n^2)。一开始写的map做法也是这个复杂度不知道为什么没过。
打cf还是尽量少用map吧。
#include<bits/stdc++.h> using namespace std; const int maxn=1e5+100; int t; int n; int a[maxn]; int c[maxn]; int cnt[maxn]; int main () { scanf("%d",&t); while (t--) { scanf("%d",&n); memset(cnt,0,sizeof(cnt)); for (int i=1;i<=n;i++) scanf("%d",&a[i]),cnt[a[i]]++; for (int i=1;i<=n;i++) c[i]=c[i-1]+a[i]; int ans=0; for (int i=1;i<=n;i++) { for (int j=i+1;j<=n;j++) if (c[j]-c[i-1]<=n&&cnt[c[j]-c[i-1]])ans+=cnt[c[j]-c[i-1]],cnt[c[j]-c[i-1]]=0; } printf("%d ",ans); } }
以上是关于CF1352E Special Permutation(桶排序+前缀和)的主要内容,如果未能解决你的问题,请参考以下文章
CF1156E Special Segments of Permutation题解瞎搞 单调栈
CF1156E Special Segments of Permutation
CF914C Travelling Salesman and Special Numbers