https://atcoder.jp/contests/abc166/tasks/abc166_e
原题解析在此
解析:满足题目要求的可能性就是这样,数理化分析后,在左边(较小数)和右边对应较大数分别有一个单变量表达式,找到相等的就可以了。
代码如下:
#include<stdio.h> int main(){ int i,n,a[200002],b[200002]={0}; long long c=0; scanf("%d",&n); for(i=0;i<n;i++)scanf("%d",&a[i]); for(i=0;i<n;i++){ if(i+a[i]<=n)b[i+a[i]]++; //较小数的算式 if(i-a[i]>=0)c+=b[i-a[i]];//较大数算式与较小数算式相等时,加上这些可能,由于较大数在较小数后面出现,不会出现漏记的情况,同时 //极大的节省了计算时间和记录空间,完美,这是我给出的图解(ps:不要计较美术,问就是灵魂画师) }printf("%lld",c); }
原文:https://www.cnblogs.com/cryforbrightfuture/p/12960863.html