一些筛法
參考
OI-wiki
素?cái)?shù)篩
埃氏篩
這個(gè)很好理解,從小到大考慮每個(gè)數(shù),將這個(gè)數(shù)的倍數(shù)標(biāo)記為合數(shù)即可,但這種篩法會(huì)對(duì)很多數(shù)重復(fù)篩,復(fù)雜度是 \(O(n\ log \ logn)\) ,于是可以使用歐拉篩。
int Eratosthenes(int n) {int cnt = 0;memset(is_prime, 1, sizeof(is_prime));is_prime[0] = is_prime[1] = 0;for (int i = 2; i <= n; ++i)if (is_prime[i]) {prime[++cnt] = i;for (int j = i * 2; j <= n; j += i) is_prime[j] = 0;}return cnt;
} 歐拉篩
即線性篩,相當(dāng)于優(yōu)化版的埃氏篩,讓每個(gè)合數(shù)只被篩一次。
復(fù)雜度: \(O(n)\)
void Euler(int n) {int cnt = 0;memset(vis, 0, sizeof(vis));for (int i = 2; i <= n; ++i) {if (!vis[i]) prime[++cnt] = i;for (int j = 1; j <= cnt && i * prime[j] <= n; ++j) {vis[i*prime[j]] = 1;if (i % prime[j] == 0) break;}}
} 求歐拉函數(shù)
利用線性篩。
void phi_table(int n) {memset(phi, 0, sizeof(phi));phi[1] = 1;for (int i = 2; i <= n; ++i)if (!phi[i]) {for (int j = i; j <= n; j += i) {if (!phi[j]) phi[j] = j;phi[j] = phi[j] / i * (i - 1);}}
}
轉(zhuǎn)載于:https://www.cnblogs.com/hlw1/p/11521440.html
總結(jié)
- 上一篇: Python爬取4399好wan的小游戏
- 下一篇: 欧拉定理 费马小定理