题解 | #万万没想到之抓捕孔连顺#

万万没想到之抓捕孔连顺

http://www.nowcoder.com/practice/c0803540c94848baac03096745b55b9b

主要变量:first(当arr[last]-arr[first]>D时,循环加1,直到小于D或first=last结束),last(一直加一输入)。
主要思路:首先不能位置重复,只需要根据输入的last++位置往前寻找即可,因为每次的last都不一样,所以位置一定不会一样,每次last+1都通过while循环动态维护first的位置,一旦确定,则可以用数学方法确定俩者之间所有的排列组合
上述数学思路:举例:(1 2 3 4 5)--6
6的位置即last位置,已确定,而包括first(1)的值有5个,在他们5个中找2个与last排列组合成3个数,C(5,2)=(5!)/((5-2)!2!),由此推导,C(last-first,2)=((last-first)!)/((last-first-2)!*2!)=(last-first)(last-first-1)/2。

#include <stdio.h>

int main()
{
    int N,D;
    while(scanf("%d %d",&N,&D)!=EOF)
    {
        int arr[N],index=0;
        long long int sum=0;
        for(int first=0,last=0;last<N;last++)
        {
            scanf("%d",&arr[last]);
            while(last>=2 && (arr[last]-arr[first])>D)
                first++;
            sum+=(long long int)(last-first-1)*(last-first)/2;
        }
        printf("%lld\n",(sum%99997867));
    }
    return 0;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-01 11:47
点赞 评论 收藏
分享
05-29 22:11
门头沟学院 Java
Elastic90:抛开学历造假不谈,这公司的招聘需求也挺怪的,Java开发还要求你有图文识别、移动端开发和c++的经验,有点逆天了。
点赞 评论 收藏
分享
认真搞学习:这么良心的老板真少见
点赞 评论 收藏
分享
评论
11
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务