• SICAU-OJ: 三角关系


    三角关系

    题意:

    给出两个数n和k,统计(a,b,c)三元组满足(a+b)%k=0,(b+c)%k=0,(a+c)%k=0且1<=a,b,c<=n的数量。

    题解:

    由(a+b)%k=0,(b+c)%k=0,(a+c)%k=0我们可以知道,a,b,c要么都为k的整数倍,要么当他们模上k时余数为k/2。

    我们现在来考虑f(n,3),即从不大于n的数里面选出可重复的3个数满足条件的个数。

    首先我们可以知道k的整数倍有cnt1 = n/k 个数,然后第二种情况有cnt2 = n/k+(n%k>=k/2)个数(前提是k为偶数)。

    因为我们是从中选数,所以是n%k>=k/2。

    对于第一种情况,不论k的奇偶都会贡献给答案。而第二种情况只有当k为偶数时才被贡献给答案。

    统计结果时就分别考率选三个不同的丶选两个相同的以及三个都相同的情况,最后加起来就是了。

    代码如下:

    #include <bits/stdc++.h>
    using namespace std;
    typedef long long ll;
    const int N =1e5+5;
    ll n,k,ans;
    int main(){
        cin>>n>>k;
        int cnt1 = n/k;
        int cnt2 = n/k+(n%k>=k/2);
        ans=(ll)cnt1*(cnt1-1)*(cnt1-2)+3ll*(cnt1-1)*cnt1+cnt1;
        if(k%2==0) ans+=(ll)cnt2*(cnt2-1)*(cnt2-2)+3ll*(cnt2-1)*cnt2+cnt2;
        cout<<ans;
        return 0;
    }
  • 相关阅读:
    windows下cmd命令行上传代码到github的指定库
    Navicat Premium 12.1.11.0安装与激活
    windows部署Apollo
    C#事件-使用事件需要的步骤
    C#委托和事件
    C#事件委托概念
    C#中委托和事件的区别
    C#委托与事件
    C#细说多线程
    C# 堆栈(Stack)和队列(Queue)
  • 原文地址:https://www.cnblogs.com/heyuhhh/p/10099416.html
Copyright © 2020-2023  润新知