标签:pre 27 19 scanf memset int 结训 ans sizeof
CF补题:
B题:只想到相隔偶数就算,但是没想好用什么方法计算,每一个都遍历肯定超啊
原来可以和滚动优化一样,只记录上一次的位置
#include <bits/stdc++.h> using namespace std; const int N=1e5+10; int a[N],pre[N],ans[N]; signed main() { int t; scanf("%d",&t); while (t--) { int n; scanf("%d",&n); memset(pre,0,sizeof pre); memset(ans,0,sizeof ans); for (int i=1;i<=n;i++) scanf("%d",&a[i]); for (int i=1;i<=n;i++) if (!pre[a[i]]||(i-pre[a[i]])%2==1) pre[a[i]]=i,ans[a[i]]++; for (int i=1;i<=n;i++) printf("%d ",ans[i]); printf("\n"); } return 0; }
标签:pre,27,19,scanf,memset,int,结训,ans,sizeof
来源: https://www.cnblogs.com/Mercury1988/p/16492763.html
本站声明:
1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。