洛谷P4213 Sum(杜教篩)

来源:https://www.cnblogs.com/zwfymqz/archive/2018/03/10/8542105.html
-Advertisement-
Play Games

題目描述 給定一個正整數N(N\le2^{31}-1)N(N≤231−1) 求ans_1=\sum_{i=1}^n\phi(i),ans_2=\sum_{i=1}^n \mu(i)ans1​=∑i=1n​ϕ(i),ans2​=∑i=1n​μ(i) 輸入輸出格式 輸入格式: 一共T+1行 第1行為數據 ...


題目描述

給定一個正整數N(N\le2^{31}-1)N(N2311)

ans_1=\sum_{i=1}^n\phi(i),ans_2=\sum_{i=1}^n \mu(i)ans1=i=1nϕ(i),ans2=i=1nμ(i)

輸入輸出格式

輸入格式:

 

一共T+1行 第1行為數據組數T(T<=10) 第2~T+1行每行一個非負整數N,代表一組詢問

 

輸出格式:

 

一共T行,每行兩個用空格分隔的數ans1,ans2

 

輸入輸出樣例

輸入樣例#1: 複製
6
1
2
8
13
30
2333
輸出樣例#1: 複製
1 1
2 0
22 -2
58 -3
278 -3
1655470 2

 

 

裸的杜教篩

$\sum_{i=1}^{n}\varphi(i) = \frac{n\times(n+1)}{2} - \sum_{d=2}^{n}\sum_{i=1}^{\lfloor\frac{n}{d}\rfloor}\varphi(i)$

$\sum_{i=1}^{n}\mu(i) = 1 - \sum_{d=2}^{n}\sum_{i=1}^{\lfloor\frac{n}{d}\rfloor}\mu(i)$

然後直接暴力遞歸計算即可

 

 

#include<cstdio>
#include<map>
#include<ext/pb_ds/assoc_container.hpp>
#include<ext/pb_ds/hash_policy.hpp>
#define LL long long 
using namespace std;
using namespace __gnu_pbds;
const int MAXN=5000030;
int N,limit=5000000,tot=0,vis[MAXN],mu[MAXN],prime[MAXN];
LL phi[MAXN];
gp_hash_table<int,LL>Aphi,Amu;
void GetMuAndPhi()
{
    vis[1]=1;phi[1]=1;mu[1]=1;
    for(int i=1;i<=limit;i++)
    {
        if(!vis[i]) prime[++tot]=i,phi[i]=i-1,mu[i]=-1;
        for(int j=1;j<=tot&&i*prime[j]<=limit;j++)
        {
            vis[i*prime[j]]=1;
            if(i%prime[j]==0){mu[i*prime[j]]=0; phi[i*prime[j]]=phi[i]*prime[j]; break;}
            else {mu[i*prime[j]]=-mu[i]; phi[i*prime[j]]=phi[i]*(prime[j]-1); }
        }
    }
    for(int i=1;i<=limit;i++) mu[i]+=mu[i-1],phi[i]+=phi[i-1];
}
LL SolvePhi(LL n)
{
    if(n<=limit) return phi[n];
    if(Aphi[n]) return Aphi[n];
    LL tmp=n*(n+1)/2;
    for(int i=2,nxt;i<=n;i=nxt+1)
        nxt=min(n,n/(n/i)),
        tmp-=SolvePhi(n/i)*(LL)(nxt-i+1);
    return Aphi[n]=tmp;
}
LL SolveMu(LL n)
{
    if(n<=limit) return mu[n];
    if(Amu[n]) return Amu[n];
    LL tmp=1;
    for(int i=2,nxt;i<=n;i=nxt+1)
        nxt=min(n,n/(n/i)),
        tmp-=SolveMu(n/i)*(LL)(nxt-i+1);
    return Amu[n]=tmp;
}
int main()
{
    GetMuAndPhi();
    int QWQ;
    scanf("%d",&QWQ);
    while(QWQ--)
    {
        scanf("%lld",&N);
        printf("%lld %lld\n",SolvePhi(N),SolveMu(N));
    }
    return 0;
}

 

 

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Lucene 是apache軟體基金會一個開放源代碼的全文檢索引擎工具包,是一個全文檢索引擎的架構,提供了完整的查詢引擎和索引引擎,部分文本分析引擎。它不是一個完整的搜索應用程式,而是為你的應用程式提供索引和搜索功能。lucene 能夠為文本類型的數據建立索引,所以你只要能把你要索引的數據格式轉化的 ...
  • 由於要學習dubbo,需要用到zookeeper,所以這裡記錄一下linux的zookeeper安裝與配置 一、下載zookeeper的包:官方地址 二、把包上傳到linux上,同樣也是放到 /usr/local 目錄下,當然同樣也是放在哪裡都行,最後解壓到 /usr/local/zookeeper ...
  • 在開發中,網路請求和json解析使用的頻率是一樣高的,因為網路請求返回來的一般都是json(當然還有xml),這裡討論的是json,網路請求的工具類前面我的博客已經寫過了,這裡給出網址:http://blog.csdn.net/u014727709/article/details/53389840 ...
  • ArrayList是一個容量能夠動態增漲的數組,它是java集合框架中一個重要的類,繼承抽象類AbstractList,實現了List介面。 實現了RandomAccess介面,該介面為標記介面,即提供了隨機訪問功能。 實現了Cloneable介面,可以調用Object的clone方法,返回對象的淺 ...
  • 實際情況是: .h文件一直報錯source file is not valid utf-8的錯誤, 原因就是: 文件中出現了一個中文的“;”導致的。總結就是:如出現此類錯誤,可能是字元不夠標準。 ...
  • JWT是一種用於雙方之間傳遞安全信息的簡潔的、URL安全的表述性聲明規範。JWT作為一個開放的標準(RFC 7519),定義了一種簡潔的,自包含的方法用於通信雙方之間以Json對象的形式安全的傳遞信息。因為數字簽名的存在,這些信息是可信的,JWT可以使用HMAC演算法或者是RSA的公私秘鑰對進行簽名。 ...
  • 一、三次握手 TCP是面向連接的,無論哪一方向另一方發送數據之前,都必須先在雙方之間建立可靠連接,連接是通過三次握手進行初始化的。三次握手的目的是同步連接雙方的序列號和確認號並交換TCP視窗大 小信息。 第一次握手:建立連接。客戶端發送連接請求報文段,將SYN設置為1,Seq設置為x,然後,客戶端進 ...
  • 4805: 歐拉函數求和 Description 給出一個數字N,求sigma(phi(i)),1<=i<=N 給出一個數字N,求sigma(phi(i)),1<=i<=N Input 正整數N。N<=2*10^9 正整數N。N<=2*10^9 Output 輸出答案。 輸出答案。 Sample I ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...