VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > temp > 简明python教程 >
  • 算法分享之关于atcoderbeginner166E的讲解

序言:博客是为了别人写?还是自己写。在我看来,博客可以帮助我记录自己的知识的欢愉,以别人的角度去审视自己的想法,博客帮助我记录自己的成长,也等待着一位位有缘人。

好了,不多说了,进入正题。回去做了做coderbeginner166的题,看到了一串非常有感觉的代码,还是一样的简洁明了。此处,原题链接

https://atcoder.jp/contests/abc166/tasks/abc166_e

原题解析在此

clip_image002

解析:满足题目要求的可能性就是这样,数理化分析后,在左边(较小数)和右边对应较大数分别有一个单变量表达式,找到相等的就可以了。

代码如下:

#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:不要计较美术,问就是灵魂画师)
}atcoder166E


相关教程