【算法學習筆記】32:篩法求解歐拉函數

上節學習的是求一個數 n n n的歐拉函數,因為用的試除法,所以時間復雜度是 O ( n ) O(\sqrt{n}) O(n ?),如果要求 m m m個數的歐拉函數,那么就會花 O ( m n ) O(m \sqrt{n}) O(mn ?)的時間。如果是求連續一批數的歐拉函數,可以用篩法進行優化。

篩法求歐拉函數原理

在線性篩求質數時可以順便把每個數的歐拉函數篩出來。根據線性篩過程,一個數要么是質數被pick出來,要么是合數被篩掉,一共有這樣三個地方:

  1. 從篩子(st數組)里發現 i i i是一個質數
  2. 合數 p r i m e s [ j ] ? i primes[j] * i primes[j]?i被篩掉,其中質數 p r i m e s [ j ] primes[j] primes[j]同時也是 i i i的質因子(按照線性篩,也一定是最小質因子)
  3. 合數 p r i m e s [ j ] ? i primes[j] * i primes[j]?i被篩掉,其中質數 p r i m e s [ j ] primes[j] primes[j]不是 i i i的質因子(僅僅是 p r i m e s [ j ] ? i primes[j] * i primes[j]?i的最小質因子)

三種情況合起來就不多不少地包含了從 1 1 1 n n n的所有數字。

  • 對于情況1,質數 i i i的歐拉函數根據定義就是除了 i i i之外的那 i ? 1 i - 1 i?1個數,因為它們一定都和 i i i互質,所以 ? ( i ) = i ? 1 \phi(i) = i - 1 ?(i)=i?1
  • 對于情況2,因為 p r i m e s [ j ] primes[j] primes[j]也是 i i i的質因子,根據歐拉公式,除了第一項外剩下那些用1減的項,都只和質因子有關,和質因子的指數無關,因此相比 ? ( i ) \phi(i) ?(i) ? ( p r i m e s [ j ] ? i ) \phi(primes[j] * i) ?(primes[j]?i)只有第一項從 i i i變成了 p r i m e s [ j ] ? i primes[j] * i primes[j]?i
  • 對于情況3,因為 p r i m e s [ j ] primes[j] primes[j]是一個質數而且和 i i i互質,因此 ? ( p r i m e s [ j ] ? i ) \phi(primes[j] * i) ?(primes[j]?i)的公式里,除了第一項要變成 p r i m e s [ j ] ? i primes[j] * i primes[j]?i,還因為添加了一個新的質數 p r i m e s [ j ] primes[j] primes[j]所以要乘以一個 1 ? 1 p r i m e s [ j ] 1 - \frac{1}{primes[j]} 1?primes[j]1?,所以總共要乘以 p r i m e s [ j ] ? 1 primes[j] - 1 primes[j]?1

例題:AcWing 874. 篩法求歐拉函數

只要利用線性篩的模板和上面的結論,在三個地方填空即可。

#include <iostream>using namespace std;typedef unsigned long long ULL;const int N = 1e6 + 10;int primes[N], cnt;
bool st[N];
int eulars[N];int main() {int n; cin >> n;eulars[1] = 1;for (int i = 2; i <= n; i ++ ) {if (!st[i]) {primes[cnt ++ ] = i;// i是質數,從1到i-1都和i互質eulars[i] = i - 1;}for (int j = 0; primes[j] * i <= n; j ++ ) {st[primes[j] * i] = true;if (i % primes[j] == 0) {// primes[j]是i的質因子,歐拉公式里只要變第一項eulars[primes[j] * i] = eulars[i] * primes[j];break;}// primes[j]不是i的質因子,歐拉公式里要變第一項和(1-1/primes[j])那項eulars[primes[j] * i] = eulars[i] * (primes[j] - 1);}}ULL res = 0;for (int i = 1; i <= n; i ++ ) {res += eulars[i];}cout << res << endl;return 0;
}

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

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

相關文章

生產管理看板助力節能科技公司實現數據自動化管理

在節能科技公司的生產過程中&#xff0c;數據管理的自動化是提高生產效率和產品質量的關鍵。然而&#xff0c;許多公司在數據記錄、展示、對比和存檔方面仍面臨諸多痛點&#xff0c;如產品檢測數據無法自動記錄、缺乏直觀的產線狀態展示、檢測數據對比繁瑣耗時&#xff0c;以及…

leetcode 115. 不同的子序列

題目&#xff1a;115. 不同的子序列 - 力扣&#xff08;LeetCode&#xff09; 動態規劃問題&#xff0c;f[i][j]表示s的第i個元素匹配到t的第j個元素&#xff0c;有多少種結果 f[i][j] f[i - 1][j] (s[i] t[j] ? f[i - 1][j - 1] : 0) 答案就是 f[s.length() - 1][t.len…

【C++】B2112 石頭剪子布

博客主頁&#xff1a; [小????????] 本文專欄: C 文章目錄 &#x1f4af;前言&#x1f4af;題目描述游戲規則&#xff1a;輸入格式&#xff1a;輸出格式&#xff1a;輸入輸出樣例&#xff1a;解題分析與實現 &#x1f4af;我的做法實現邏輯優點與不足 &#x1f4af…

內存快照:宕機后Redis如何實現快速恢復?

文章目錄 給哪些內存數據做快照&#xff1f;快照時數據能修改嗎?可以每秒做一次快照嗎&#xff1f;小結每課一問 更多redis相關知識 上節課&#xff0c;我們學習了 Redis 避免數據丟失的 AOF 方法。這個方法的好處&#xff0c;是每次執行只需要記錄操作命令&#xff0c;需要持…

系統架構設計師考點—項目管理

一、備考指南 項目管理主要考查的是進度管理、軟件配置管理、質量管理、風險管理等相關知識&#xff0c;近幾年都沒有考查過&#xff0c;但是有可能在案例分析中考查關鍵路徑的技術問題&#xff0c;考生了解為主。 二、重點考點 1、項目的十大管理&#xff08;速記&#xff1…

iOS - Objective-C 底層實現中的哈希表

1. 關聯對象存儲&#xff08;AssociationsHashMap&#xff09; // 關聯對象的哈希表實現 typedef DenseMap<const void *, ObjcAssociation> ObjectAssociationMap; typedef DenseMap<DisguisedPtr<objc_object>, ObjectAssociationMap> AssociationsHashMa…

兩分鐘解決 :![rejected] master -> master (fetch first) , 無法正常push到遠端庫

目錄 分析問題的原因解決 分析問題的原因 在git push的時候莫名遇到這種情況 若你在git上修改了如README.md的文件。由于本地是沒有README.md文件的&#xff0c;所以導致 遠端倉庫git和本地不同步。 將遠端、本地進行合并就可以很好的解決這個問題 注意&#xff1a;直接git pu…

Ubuntu Server 24.04 配置靜態IP

Ubuntu Server 24.04 配置靜態IP 提示&#xff1a;基于Ubuntu Server 24.04進行配置 文章目錄 Ubuntu Server 24.04 配置靜態IP一、查看網卡信息二、修改網卡信息三、使網卡配置生效四、測試 一、查看網卡信息 使用命令 ip a lo 為本地回環地址 ens33 真實網卡地址 shanfengubu…

微服務之松耦合

參考&#xff1a;https://microservices.io/post/architecture/2023/03/28/microservice-architecture-essentials-loose-coupling.html There’s actually two different types of coupling: runtime coupling - influences availability design-time coupling - influences…

Django 和 Vue3 前后端分離開發筆記

Django 和 Vue3 前后端分離開發筆記 1. Django Ninja API Django Ninja 是一個用于使用 Django 和 Python 3.6 類型提示構建 API 的網絡框架。它具有以下主要特點&#xff1a; 簡單易懂&#xff1a;設計為易于使用和符合直覺&#xff0c;適合快速上手。快速執行&#xff1a;…

44_Lua迭代器

在Lua中,迭代器是一種用于遍歷集合元素的重要工具。掌握迭代器的使用方法,對于提高Lua編程的效率和代碼的可讀性具有重要意義。 1.迭代器概述 1.1 迭代器介紹 迭代器是一種設計模式,它提供了一種訪問集合元素的方法,而不需要暴露其底層結構。在Lua中,迭代器通常以一個函…

hot100_240. 搜索二維矩陣 II

hot100_240. 搜索二維矩陣 II 直接遍歷列減行增 編寫一個高效的算法來搜索 m x n 矩陣 matrix 中的一個目標值 target 。該矩陣具有以下特性&#xff1a; 每行的元素從左到右升序排列。 每列的元素從上到下升序排列。 示例 1&#xff1a; 輸入&#xff1a;matrix [[1,4,7,1…

一步到位Python Django部署,淺談Python Django框架

Django是一個使用Python開發的Web應用程序框架&#xff0c;它遵循MVC&#xff08;Model-View-Controller&#xff09;設計模式&#xff0c;旨在幫助開發人員更快、更輕松地構建和維護高質量的Web應用程序。Django提供了強大的基礎設施和工具&#xff0c;以便于處理復雜的業務邏…

Apache PAIMON 學習

參考&#xff1a;Apache PAIMON&#xff1a;實時數據湖技術框架及其實踐 數據湖不僅僅是一個存儲不同類數據的技術手段&#xff0c;更是提高數據分析效率、支持數據驅動決策、加速AI發展的基礎設施。 新一代實時數據湖技術&#xff0c;Apache PAIMON兼容Apache Flink、Spark等…

《計算機網絡》課后探研題書面報告_了解PPPoE協議

PPPoE協議的工作原理與應用分析 摘 要 PPPoE&#xff08;Point-to-Point Protocol over Ethernet&#xff09;是一種廣泛應用于寬帶接入的網絡協議&#xff0c;特別是在DSL&#xff08;數字用戶線路&#xff09;和光纖網絡中具有重要的應用價值。PPPoE結合了PPP協議的認證、加…

【MySQL學習筆記】MySQL存儲過程

存儲過程 1、基礎語法2、變量2.1 系統變量2.2 用戶自定義變量2.3 局部變量 3、if 流程控制4、參數5、case 流程控制6、循環結構6.1 while 循環6.2 repeat 循環6.3 loop 循環 7、游標8、存儲函數 存儲過程是事先經過編譯并存儲在數據庫中的一段 SQL 語句的集合&#xff0c;調用存…

MAC上安裝Octave

1. 當前最新版Octave是9.3版本&#xff0c;需要把mac os系統升級到14版本&#xff08;本人之前的版本是10版本&#xff09; https://wiki.octave.org/Octave_for_macOS octave的歷史版本參考此文檔&#xff1a;Octave for macOS (outdated) - Octavehttps://wiki.octave.org/Oc…

mysql-5.7.18保姆級詳細安裝教程

本文主要講解如何安裝mysql-5.7.18數據庫&#xff1a; 將綠色版安裝包mysql-5.7.18-winx64解壓后目錄中內容如下圖&#xff0c;該例是安裝在D盤根目錄。 在mysql安裝目錄中新建my.ini文件&#xff0c;文件內容及各配置項內容如下圖&#xff0c;需要先將配置項【skip-grant-tab…

VSCode連接Github的重重困難及解決方案!

一、背景&#xff1a; 我首先在github創建了一個新的項目&#xff0c;并自動創建了readme文件其次在vscode創建項目并寫了兩個文件在我想將vscode的項目上傳到對應的github上時&#xff0c;錯誤出現了 二、報錯及解決方案&#xff1a; 1.解決方案&#xff1a; 需要在git上配置用…

YOLOV8漲點技巧之混合注意力與特征金字塔網絡融合

YOLO發展歷程 自2015年YOLOv1問世以來,這一革命性的目標檢測算法經歷了一系列重大升級。以下是YOLO各版本的主要發展里程碑: 版本 發布時間 主要開發者 YOLOv1 2015年6月 Joseph Redmon YOLOv2(YOLO9000) 2016年12月 Joseph Redmon YOLOv3 2018年4月 Joseph Redmon