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

万万没想到之抓捕孔连顺

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;
}
全部评论

相关推荐

05-19 19:57
蚌埠学院 Python
2237:Gpa70不算高,建议只写排名,个人技能不在多而在精,缩到8条以内。项目留一个含金量高的,减少间距弄到一页,硕士简历也就一页,本科不要写很多
实习,投递多份简历没人回...
点赞 评论 收藏
分享
仁者伍敌:难怪小公司那么挑剔,让你们这些大佬把位置拿了
点赞 评论 收藏
分享
评论
11
2
分享

创作者周榜

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