双指针

rt
#include<bits/stdc++.h>
 
using namespace std;
const long long maxn=1e6+7;
long long a[maxn*2];
int main()
{
    long long n,l;
    cin >> n >> l;
    for(long long i=0;i<n;i++)cin>>a[i],a[i+n]=l+a[i];
    sort(a,a+2*n);
    double half_c=l/2.0;
    long long ans=0;
    for(long long l=0,r=0;l<n;l++){
        while(a[r]-a[l]<half_c)r++;
        r--;
        long long len=r-l;
        //cout<<len<<endl;
        ans+=(len)*(len-1)/2;
    }
    cout<<((n-1)*(n-2)*n/(2*3)-ans)<<endl;
    return 0;
}


全部评论

相关推荐

昨天 14:30
复旦大学 Java
遇到这种人我也不知道说啥了
正义执行官:人家能回你就不错了,自己不主动去问,等着天上掉馅饼,想啥呢哥们
点赞 评论 收藏
分享
一表renzha:手写数字识别就是一个作业而已
点赞 评论 收藏
分享
不要停下啊:大二打开牛客,你有机会开卷了,卷起来,去找课程学习,在牛客上看看大家面试笔试都需要会什么,岗位有什么需求就去学什么,努力的人就一定会有收获,这句话从来都经得起考验,像我现在大三了啥也不会,被迫强行考研,炼狱难度开局,啥也不会,找工作没希望了,考研有丝丝机会
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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