zoukankan      html  css  js  c++  java
  • 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;
    }
  • 相关阅读:
    Spring Could与Dubbo、Docker、K8S
    Spring Could 问题
    再看Spring Could微服务的关键组件
    2018第46周日
    好用的天猫精灵
    好用的微软桌面
    PostgreSQL性能极限
    微服务常见问题及解决方案
    最近看到的几本书
    程序员如何修炼管理思维
  • 原文地址:https://www.cnblogs.com/heyuhhh/p/10099416.html
Copyright © 2011-2022 走看看