杜教篩--51nod1239 歐拉函數之和

求$\sum_{i=1}^{n}\varphi (i)$,$n\leqslant 1e10$。

這里先把杜教篩的一般套路貼一下:

要求$S(n)=\sum_{i=1}^{n}f(i)$,而現在有一數論函數$g(i)$,$g(i)$的前綴和很無腦,且$f$和$g$的狄利克雷卷積的前綴和很無腦(太巧了吧。。),那么由

$\sum_{i=1}^{n}\sum_{d|i}f(d)g(\frac{i}{d})$

閃一句,常用套路:設$i=kd$,轉而枚舉$k$。

$=\sum_{k=1}^{n}g(k)\sum_{d=1}^{\left \lfloor \frac{n}{k} \right \rfloor}f(d)$

$=\sum_{k=1}^{n}g(k)S(\frac{n}{k})$

可得

$g(1)S(n)=\sum_{i=1}^{n}\sum_{d|i}f(d)g(\frac{i}{d})-\sum_{k=2}^{n}g(k)S(\left \lfloor \frac{n}{k} \right \rfloor)$

進而遞推求S。

官方復雜度:(假如構造的卷積的前綴和和g的前綴和都是O(1)可知)由于S那個除法的取值范圍:1,2,……,m-1,m,n/m,n/(m-1),……,n,

可以想到預處理一部分再算一部分,假設預處理了$n^k$,那么總的復雜度就是:$max(n^k,沒預處理的那一段)$,

沒預處理的那段就是$\sum_{i=1}^{n^{1-k}}\sqrt{\frac{n}{i}}=n^{\frac{1}{2}}\sum_{i=1}^{n^{1-k}}i^{-\frac{1}{2}}\approx n^{\frac{1}{2}}n^\frac{1-k}{2}$

所以總的復雜度就是$max(n^k,n^{\frac{1}{2}}n^\frac{1-k}{2})$,當$\frac{1}{2}+\frac{1-k}{2}=k$時取得最小復雜度,$k=\frac{2}{3}$.

然而我這里有點不懂:因為沒預處理的那段我們是直接遞歸+記憶化的,那記憶化的那部分復雜度怎么算?如何證明杜教篩過程中出現的數字個數的上限?暫不知。先用著。

好那這道題,我們要找一個前綴和無腦且和$\varphi $乘起來無腦的一個函數--1!——就是f(x)=1不知道叫什么——因為有$\varphi *1=Id$,$Id(x)=x$。

那就帶進去玩一玩:

$\sum_{i=1}^{n}\sum_{d|i}\varphi (d)=\sum_{k=1}^{n}1\sum_{d=1}^{\left \lfloor \frac{n}{k} \right \rfloor}\varphi (d)= \sum_{k=1}^{n}S(\left \lfloor \frac{n}{k} \right \rfloor)$

玩夠一百下再玩一百下:

$S(n)=\sum_{i=1}^{n}\sum_{d|i}1*\varphi (d)-\sum_{k=2}^{n}S(\left \lfloor \frac{n}{k} \right \rfloor)=\frac{n(n+1)}{2}-\sum_{k=2}^{n}S(\left \lfloor \frac{n}{k} \right \rfloor)$。

OK丟去篩吧。

 1 #include<string.h>
 2 #include<stdlib.h>
 3 #include<stdio.h>
 4 #include<math.h>
 5 //#include<assert.h>
 6 #include<algorithm> 
 7 //#include<iostream>
 8 //#include<bitset>
 9 using namespace std;
10 
11 #define LL long long
12 LL n,m;
13 #define maxn 5000011
14 const int mod=1e9+7;
15 int phi[maxn],sumphi[maxn],prime[maxn/10],lp; bool notprime[maxn];
16 void pre(int n)
17 {
18     lp=0; phi[1]=1; sumphi[1]=1;
19     for (int i=2;i<=n;i++)
20     {
21         if (!notprime[i]) {prime[++lp]=i; phi[i]=i-1;}
22         sumphi[i]=sumphi[i-1]+phi[i];
23         sumphi[i]-=sumphi[i]>=mod?mod:0;
24         for (int j=1,tmp;j<=lp && 1ll*prime[j]*i<=n;j++)
25         {
26             notprime[tmp=i*prime[j]]=1;
27             if (i%prime[j]) phi[tmp]=1ll*phi[i]*(prime[j]-1)%mod;
28             else {phi[tmp]=1ll*phi[i]*prime[j]%mod; break;}
29         }
30     }
31 }
32 
33 struct Edge{LL to; int v,next;};
34 #define maxh 1000007
35 struct Hash
36 {
37     int first[maxh],le;Edge edge[maxn];
38     Hash() {le=2;}
39     void insert(LL y,int v)
40     {int x=y%maxh; Edge &e=edge[le]; e.to=y; e.v=v; e.next=first[x]; first[x]=le++;}
41     int find(LL y)
42     {
43         int x=y%maxh;
44         for (int i=first[x];i;i=edge[i].next) if (edge[i].to==y) return edge[i].v;
45         return -1;
46     }
47 }h;
48 
49 int du(LL n)
50 {
51     if (n<=m) return sumphi[n];
52     int tmp=h.find(n); if (tmp!=-1) return tmp;
53     LL tot=0;
54     for (LL i=2,last;i<=n;i=last+1)
55     {
56         last=n/(n/i);
57         tot+=(last-i+1)*du(n/i)%mod;
58         tot-=tot>=mod?mod:0;
59     }
60     LL ans=(n%mod)*((n+1)%mod)%mod*((mod+1)>>1)%mod-tot;
61     ans+=ans<0?mod:0;
62     h.insert(n,ans);
63     return ans;
64 }
65 
66 int main()
67 {
68     scanf("%lld",&n);
69     m=(LL)pow(pow(n,1.0/3),2); pre(m);
70     printf("%d\n",du(n));
71     return 0;
72 }
View Code

?

轉載于:https://www.cnblogs.com/Blue233333/p/8315576.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/390325.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/390325.shtml
英文地址,請注明出處:http://en.pswp.cn/news/390325.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【Android Studio安裝部署系列】目錄

概述 從剛開始使用Android Studio到現在&#xff0c;下面所有目錄下的操作&#xff0c;當時習慣性的把每一個整理成一個文檔&#xff08;其實就是簡單文字描述截圖&#xff09;&#xff1b;有些地方當時是一知半解&#xff0c;現在會稍微明白一些。正好趕上現在有時間。所以就想…

修改npm全局安裝模式的路徑

修改npm全局安裝模式的路徑 在正式寫此文章之前&#xff0c;我得說一點血淚史。 剛學nodeJS不久&#xff0c;很納悶為什么全局安裝的模塊在 node安裝目錄/node_modules‘ 中沒找到&#xff01;后來仔細看了下安裝成功后的信息&#xff0c;才發現原來是自動安裝在C盤了&#xff…

javascript創建類_如何使用JavaScript創建吹氣效果

javascript創建類Have you ever wondered how you can create a realistic air blowing effect with JavaScript? Like the one shown on the evening TV shows, where multiple balls are being mixed up in a sphere-like object by leveraging air pressure? If you want …

Bootstrap 4:如何使頂部固定的Navbar保持在容器中而不拉伸?

There are many ways to make a fixed navbar stay inside a parents div container. Well go over the most straightforward one here.有很多方法可以使固定的導航欄停留在父級的div容器中。 我們將在這里介紹最簡單的方法。 Imagine you have the following code, modified…

基于SpringBoot+Mybatis+Thymeleaf商品信息管理系統

github地址&#xff1a;github.com/zaiyunduan1…,如果對你有幫助&#xff0c;歡迎Star 主要用到的技術&#xff1a; 使用maven進行項目構建使用SpringbootMybatis搭建整個系統使用Thymeleaf模板技術實現頁面靜態化使用框架Bootstrap、JQuery開發前端界面使用MySQL和MongoDB分別…

在Mac上為自己手動編譯安裝一套PHP7的開發環境

首先你得去官網下載php7 beta1的版本 這里由于我是在mac上安裝&#xff0c;所以就去下載linux相關的版本&#xff0c;地址也直接附上了php7 beta1windows版的官方也有發布詳情猛戳&#xff1a;這里 解壓安裝包&#xff0c;進入源代碼目錄 tar -zxvf php-7.0.0beta1.tar.gz cd p…

卡特蘭數 HDU2067 HDU4165 HDU1134

題目鏈接&#xff1a;https://vjudge.net/problem/HDU-2067 小兔的棋盤 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 11800 Accepted Submission(s): 5952 Problem Description小兔的叔叔從外面旅游回來給她…

Python的用途是什么? Python編程語言有10多種編碼用途。

&#x1f44b;歡迎 (&#x1f44b; Welcome) Hi! Please take a moment to think about this question: 嗨&#xff01; 請花一點時間考慮這個問題&#xff1a; How is Python applied in real-world scenarios? Python如何在實際場景中應用&#xff1f; If you are learnin…

Publish/Subscribe

Publish/Subscribe 我們將會投遞一個消息給多個消費者&#xff0c;這種模式被稱為“publish/subscribe” 通俗的講&#xff0c;前面的是點對點隊列模型&#xff0c;現在講的是發布訂閱模型。 Exchanges producer&#xff1a;一個發送消息的用戶應用程序 queue&#xff1a;一個存…

[轉]在ROS下使用zeroconf配置多機通信

原文地址&#xff1a;http://www.corvin.cn/635.html&#xff0c;轉載主要方便隨時查閱&#xff0c;如有版權要求&#xff0c;請及時聯系。 0x00 為何需要配置ROS多機通信 眾所周知ROS是分布式系統&#xff0c;因此可以將機器人需要處理的復雜、計算量大的任務分解在多臺機器上…

python中斐波那契數列_斐波那契數列–在Python,JavaScript,C ++,Java和Swift中進行了解釋...

python中斐波那契數列by Pau Pavn通過保羅帕文(PauPavn) The Fibonacci sequence is, by definition, the integer sequence in which every number after the first two is the sum of the two preceding numbers. To simplify:根據定義&#xff0c;斐波那契數列是整數序列&a…

1583. 統計不開心的朋友

1583. 統計不開心的朋友 給你一份 n 位朋友的親近程度列表&#xff0c;其中 n 總是 偶數 。 對每位朋友 i&#xff0c;preferences[i] 包含一份 按親近程度從高到低排列 的朋友列表。換句話說&#xff0c;排在列表前面的朋友與 i 的親近程度比排在列表后面的朋友更高。每個列…

uva 247(floyd傳遞閉包)

為什么&#xff0c;逗號后面&#xff0c;還有空格........ #include <iostream> #include <cstring> #include <algorithm> #include <cstdio> #include <vector> #include <map> using namespace std; const int maxn50; int d[maxn][max…

VS Code 的常用快捷鍵和插件

注:文章摘自 風行天下一萬號 - 博客園 vs code 的常用快捷鍵 1、注釋&#xff1a; 單行注釋&#xff1a;[ctrlk,ctrlc] 或 ctrl/取消單行注釋&#xff1a;[ctrlk,ctrlu] (按下ctrl不放&#xff0c;再按k u)多行注釋&#xff1a;[altshiftA]多行注釋&#xff1a;/**2、移動行&a…

python包numpy_NumPy Python科學計算軟件包的終極指南

python包numpyNumPy (pronounced "numb pie") is one of the most important packages to grasp when you’re starting to learn Python.NumPy(讀作“麻木派”)是您開始學習Python時要掌握的最重要的軟件包之一。 The package is known for a very useful data str…

NGINX原理 之 SLAB分配機制(轉)

1 引言 眾所周知&#xff0c;操作系統使用伙伴系統管理內存&#xff0c;不僅會造成大量的內存碎片&#xff0c;同時處理效率也較低下。SLAB是一種內存管理機制&#xff0c;其擁有較高的處理效率&#xff0c;同時也有效的避免內存碎片的產生&#xff0c;其核心思想是預分配。其按…

apk之間數據共享的方式

1、四大組件之ContentProvider大法2、shareUserId3、apk均去遠端獲取配置文件&#xff08;或接口&#xff09;4、AIDL&#xff08;bindService&#xff09;5、SharePreference設置為MODE_WORLD_READABLE|MODE_WORLD_WRITEABLE模式&#xff0c;由于存在安全問題&#xff0c;已被…

藍橋杯java 基礎練習 十六進制轉十進制

問題描述從鍵盤輸入一個不超過8位的正的十六進制數字符串&#xff0c;將它轉換為正的十進制數后輸出。注&#xff1a;十六進制數中的10~15分別用大寫的英文字母A、B、C、D、E、F表示。樣例輸入FFFF樣例輸出65535import java.math.BigInteger; import java.util.Scanner;public …

dynamic web module消失不見

2019獨角獸企業重金招聘Python工程師標準>>> 方法1&#xff1a;在project Facets選項中勾選Dynamic Web Module即可 方法2&#xff1a; 我用eclipse對項目進行修改名稱&#xff0c;修改成功后。項目就沒有Deployment Descriptor&#xff08;如下圖紅色框中&#xff…

576. 出界的路徑數

576. 出界的路徑數 給你一個大小為 m x n 的網格和一個球。球的起始坐標為 [startRow, startColumn] 。你可以將球移到在四個方向上相鄰的單元格內&#xff08;可以穿過網格邊界到達網格之外&#xff09;。你 最多 可以移動 maxMove 次球。 給你五個整數 m、n、maxMove、star…