质数k次方求和

质数的0次方和,也就是质数个数。

已通过wolfram alpha验证。

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 sum(ll n) {
    n %= mod;
    return n;
}

const int MAXN = 1e6 + 5;

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

ll prime_cnt(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);
                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);
            ssum[i] = sub_mod(ssum[i], tmp);
        }
    }
    return lsum[1];
}

质数的1次方和,也就是质数求和。

已通过wolfram alpha验证。
已通过HDU的2020CCPC的1002验证。

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;
}

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];
}

低次的求和,用拉格朗日插值求出来,然后再改动一下tmp = mul_mod(tmp, p);这里。

全部评论

相关推荐

评论
1
收藏
分享

创作者周榜

更多
正在热议
更多
# 听劝,这个简历怎么改 #
14081次浏览 182人参与
# 面试被问“你的缺点是什么?”怎么答 #
6309次浏览 98人参与
# 水滴春招 #
16286次浏览 346人参与
# 入职第四天,心情怎么样 #
11280次浏览 63人参与
# 租房找室友 #
8005次浏览 53人参与
# 读研or工作,哪个性价比更高? #
26151次浏览 356人参与
# 职场新人生存指南 #
199185次浏览 5509人参与
# 参加完秋招的机械人,还参加春招吗? #
26960次浏览 276人参与
# 文科生还参加今年的春招吗 #
4108次浏览 31人参与
# 简历无回复,你会继续海投还是优化再投? #
48619次浏览 561人参与
# 你见过最离谱的招聘要求是什么? #
144708次浏览 829人参与
# 如果重来一次你还会读研吗 #
155714次浏览 1706人参与
# 机械人选offer,最看重什么? #
69076次浏览 449人参与
# 选择和努力,哪个更重要? #
44269次浏览 492人参与
# 如果再来一次,你还会学硬件吗 #
103643次浏览 1245人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
20519次浏览 413人参与
# 招聘要求与实际实习内容不符怎么办 #
46703次浏览 494人参与
# 22届毕业,是读研还是拿外包offer先苟着 #
4652次浏览 27人参与
# 你们的毕业论文什么进度了 #
901211次浏览 8960人参与
# 软开人,你觉得应届生多少薪资才算合理? #
81371次浏览 496人参与
# 国企还是互联网,你怎么选? #
109189次浏览 853人参与
牛客网
牛客企业服务