B: Graph Theory Class

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6889
伪图论题,板子找的好就能A。
大概要求出这个东西:
lcm(2,3)+min(lcm(2,4),lcm(3,4))+min(lcm(2,4),lcm(3,4))+min(lcm(2,5),lcm(3,5),lcm(4,5))...
我们可以通过唯一分解定理的思路来取min,从i=3开始,若是一个质数,那么lcm取min后肯定是2*i,若不是一个质数,那么肯定为这个数自己,因此,我们的目标就是求i=3开始到n+1(注意)的数的和加上i=3开始的质数的和。鉴于n=1e11,直接套板子。
值得注意的是n为1e11,那么利用求和公式求和的时候别忘了一步一取模。
代码:

#include<bits/stdc++.h>
using namespace std;
#define int long long
typedef long long ll;

int mod;

inline ll add_mod(ll x, ll y) {
    return (x + y >= mod) ? (x + y - mod) : (x + y);
}

inline ll sub_mod(ll x, ll y) {
    return (x < y) ? (x - y + mod) : (x - y);
}

inline ll mul_mod(ll x, ll y) {
    return x * y % mod;
}

inline ll sum(ll n) {
    n %= mod;
    return (n * (n + 1)) / 2 % mod;
}
inline ll q_pow(ll a, ll b){
    ll ans = 1;
    while(b > 0){
        if(b & 1){
            ans = ans * a % mod;
        }
        a = a * a % mod;
        b >>= 1; 
    } 
    return ans;
}

const int MAXN = 1e6 + 5;

ll ssum[MAXN];
ll lsum[MAXN];
bool mark[MAXN];

ll prime_sum(ll n) {
    const int v = sqrt(n);
    ssum[0] = 0;
    lsum[0] = 0;
    memset(mark, 0, sizeof(mark[0]) * (v + 1));
    for(ll i = 1; i <= v; ++i) {
        ssum[i] = sum(i) - 1;
        lsum[i] = sum(n / i) - 1;
    }
    for(ll p = 2; p <= v; ++p) {
        if(ssum[p] == ssum[p - 1])
            continue;
        ll psum = ssum[p - 1];
        ll q = p * p;
        ll ed = min((ll)v, n / q);
        ll delta1 = (p & 1) + 1;
        for(ll i = 1; i <= ed; i += delta1) {
            if(!mark[i]) {
                ll d = i * p;
                ll tmp = (d <= v) ? lsum[d] : ssum[n / d];
                tmp = sub_mod(tmp, psum);
                tmp = mul_mod(tmp, p);
                lsum[i] = sub_mod(lsum[i], tmp);
            }
        }
        ll delta2 = p * delta1;
        for(ll i = q; i <= ed; i += delta2)
            mark[i] = 1;
        for(ll i = v; i >= q; --i) {
            ll tmp = ssum[i / p];
            tmp = sub_mod(tmp, psum);
            tmp = mul_mod(tmp, p);
            ssum[i] = sub_mod(ssum[i], tmp);
        }
    }
    return lsum[1];
}

signed main()
{
    int t;
    cin >> t;
    while(t--)
    {
        int n;
        cin >> n >> mod;
        int inv2 = q_pow(2, mod-2);
        int ans1 = (n+4)%mod*(n-1)%mod*inv2%mod;
        int ans2 = (prime_sum(n+1)-2 + mod )%mod;
        cout << (ans1+ans2)%mod << endl;
    }
}
2020 CCPC网络赛 文章被收录于专栏

~

全部评论

相关推荐

评论
2
收藏
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
8542次浏览 77人参与
# 你的实习产出是真实的还是包装的? #
1566次浏览 40人参与
# 米连集团26产品管培生项目 #
5484次浏览 214人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7320次浏览 40人参与
# 简历第一个项目做什么 #
31468次浏览 323人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
186755次浏览 1118人参与
# MiniMax求职进展汇总 #
23648次浏览 305人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152222次浏览 887人参与
# 研究所笔面经互助 #
118833次浏览 577人参与
# 重来一次,我还会选择这个专业吗 #
433251次浏览 3926人参与
# 简历中的项目经历要怎么写? #
309889次浏览 4181人参与
# 面试紧张时你会有什么表现? #
30463次浏览 188人参与
# 你今年的平均薪资是多少? #
212941次浏览 1039人参与
# AI时代,哪些岗位最容易被淘汰 #
63209次浏览 791人参与
# 我的求职精神状态 #
447934次浏览 3128人参与
# 你最满意的offer薪资是哪家公司? #
76375次浏览 374人参与
# 正在春招的你,也参与了去年秋招吗? #
363077次浏览 2635人参与
# 你怎么看待AI面试 #
179724次浏览 1223人参与
# 牛客AI文生图 #
21391次浏览 237人参与
# 职能管理面试记录 #
10776次浏览 59人参与
# 网易游戏笔试 #
6445次浏览 83人参与
# 腾讯音乐求职进展汇总 #
160536次浏览 1109人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务