POJ 2773 欧拉函数, 素数表
来源:互联网 发布:淘宝假发多少钱 编辑:程序博客网 时间:2024/06/05 01:03
这题很很很不懂,谁能详细讲解下。
素数表第一次用,用了不熟练,欧拉函数求了好久出来,不太懂。
#include <stdio.h>#include <string.h>#include <math.h>#define MAXN 1000010int prime[MAXN], phi[MAXN];void Init(){int i, j, k = ceil(sqrt(1000010));//求素数表memset(prime, 0, sizeof(prime));prime[0] = prime[1] = 1;for (i = 2; i < k; i++){if (prime[i] == 0){for (j = 2 * i; j < MAXN; j += i)prime[j] = 1;}}//求欧拉函数值for (i = 1; i < MAXN; i++)phi[i] = i;for (i = 2; i < MAXN; i++){if (prime[i] == 0){for (j = i; j < MAXN; j += i)//phi(n) = n * (1 - 1/p1) * (1 - 1/p2)....[pi是与n的质因素]phi[j] = phi[j] / i * (i - 1);}}}int GCD(int a, int b){int t;while (b){t = b;b = a % b;a = t;}return a;}int main(){int m, K, cnt, i, flag, mul;Init();while (scanf("%d%d", &m, &K) != EOF){//判断m内第几个与m互素cnt = K % phi[m];//判断分为了几组mul = K / phi[m];//正好分为整数组if (cnt == 0){//m的最后一个与其互素的cnt = phi[m];//分组减一mul--;}flag = 0;for (i = 1; i < m; i++)//判断是否互素if (GCD(m, i) == 1){flag++;if (flag == cnt)break;}//printf("phi[m] = %d i = %d mul = %d\n", phi[m], i, mul);printf("%d\n", mul * m + i);}return 0;}这个是我第n次RE后写的,超时了,有什么特别好的优化方法吗? 请教下大家
#include <stdio.h>int Coprime (int a, int b){int t;while (b){t = b;b = a % b;a = t;}if (a == 1)return 1;return 0;}int main(){int i, m, cnt, K, flag, phi_m, mul;while (scanf("%d%d", &m, &K) != EOF){phi_m = flag = 0;for (i = 1; i <= m; i++)if (Coprime(m, i))phi_m++;cnt = K % phi_m;mul = K / phi_m;if (cnt == 0){cnt = phi_m;mul--;}for (i = 1; i <= m; i++)if (Coprime(m, i)){flag++;if (flag == cnt)break;}printf("%d\n", mul * m + i);}return 0;}
今天又练了到素数表的题, 不过时间好慢200+MS 不知道别人的0MS怎么弄出来的
有谁知道怎么优化比较好, 发个链接, 谢谢。
POJ 3006 筛素数
#include <stdio.h>#include <string.h>int prime[1000010];void init(){int i, j;memset(prime, 0, sizeof(prime));prime[0] = prime[1] = 1;for (i = 2; i < 1000; i++){if (prime[i] == 0)for (j = 2 * i; j < 1000000; j += i)prime[j] = 1;}}int main(){int a, d, n, num, i;init();while (scanf("%d %d %d", &a, &d, &n) != EOF){if (!(a || d || n)) break;num = i = 0;while (num != n){if (prime[a + i * d] == 0) num++;i++;}printf("%d\n", a + (i - 1) * d);}return 0;}
- POJ 2773 欧拉函数, 素数表
- 欧拉函数 + 约数 + 素数表 + 欧拉函数表
- poj 2478【线性筛素数+欧拉函数】
- 欧拉函数 素数原根 POJ 1284
- poj 1284欧拉函数求素数元根个数
- Lightoj1007【欧拉函数-素数表】
- Relatives+水题+欧拉函数+素数打表的基本应用+poj
- 欧拉函数 最大素因数 素数判断 素数表
- poj 2773(欧拉函数)
- POJ 2773 欧拉函数
- 欧拉函数筛选素数
- 素数欧拉函数同时筛和打表
- POJ 2773 Happy 2006 欧拉函数
- POJ 2773-Happy 2006(欧拉函数)
- 素数 约数 欧拉函数 筛法
- csu(欧拉函数+筛素数)
- 欧拉函数 素数筛选法模板
- 欧拉函数求法与欧拉筛法求素数
- 【转】经典的01背包问题
- 【最小生成树】神母牛的实验
- 编程珠玑第十二章 生成有序随机序列
- How To Access Forms Directly In Oracle Applications R12 [ID 552301.1]
- HDU 1525 Euclid's Game (博弈)
- POJ 2773 欧拉函数, 素数表
- Hdu 2222 [AC自动机]
- 移动平台的产品设计世界
- I2S总线协议 .
- HDU OJ 4334 Trouble 【hash】
- lotus表单中对文本域和富文本域的处理
- ThinkPHP3.0所有echo都输出两次
- Qt中添加背景图片的方法(转)
- struts2-json-plugin中文手册