Project Euler_Problem 193_Few Repeated Digits_欧拉筛+容斥公式

原题目:

题目大意:

解题思路:

代码:

cpp 复制代码
void serch(ll I,ll sum,ll used) {
    ll i, j, l, x,y;

    
    for (i = 1; i < I; i++) {
        if (sum * D[i] > N)break;
        x = sum * D[i];
        y = N / x;

        if (used % 2 == 0) {
            ans1 = ans1 - y;
        }
        else {
            ans1 = ans1 + y;
        }

        serch(i, x, used + 1);

    }

}


void solve() {
    ll i, j,k,x,y,z,p,q,u,v;
    N = (( (ll)1 )<<50), NN = 4;
    //N = 20;
    double a, b, c,d;
    M.NT.get_prime_Euler(100000000);
    
    for (i = 1; i <= M.NT.pcnt; i++) {
        x = M.NT.prime[i];
        if (x * x > N)break;
    }

    ll len = i - 1;

    for (i = 1; i <= len; i++) {
        D[i] = M.NT.prime[i] * M.NT.prime[i];
        ans1 = ans1 + N / D[i];
    }

    for (i = len; i >= 1; i--) {
        serch(i, D[i], 2);
    }
    

    printf("%lld\n",N-ans1);
}
相关推荐
iFlow_AI几秒前
iFlow CLI快速搭建Flutter应用记录
开发语言·前端·人工智能·flutter·ai·iflow·iflow cli
兔子零10242 分钟前
前端开发实战笔记:为什么从 Axios 到 TanStack Query,是工程化演进的必然?
前端
牢七2 分钟前
Javan
java
面向div编程2 分钟前
Vite的知识点
前端
疯狂踩坑人5 分钟前
【前端工程化】一文看懂现代Monorepo(npm)工程
前端·npm·前端工程化
JarvanMo8 分钟前
Flutter:如何更改默认字体
前端
默海笑8 分钟前
VUE后台管理系统:定制化、高可用前台样式处理方案
前端·javascript·vue.js
我叫黑大帅11 分钟前
六边形架构?小白也能秒懂的「抗造代码秘诀」
java·后端·架构
不穿格子的程序员12 分钟前
Java基础篇——JDK新特性总结
java·虚拟线程·jdk新特性
YaeZed15 分钟前
Vue3-toRef、toRefs、toRaw
前端·vue.js