HDU-2138-How many prime numbers(Miller-Rabin新解法)
题目传送门
sol1:普通判到sqrt(n)的素数判定,不多说了。
- 素数判定
#include "bits/stdc++.h"
using namespace std;
bool is_prime(int n) {
for (int i = ; 1LL * i * i <= n; i++)
{
if (n % i == ) return false;
}
return true;
}
int main() {
int n, m;
while (~scanf("%d", &n)) {
int cnt = ;
for (int i = ; i <= n; i++) {
scanf("%d", &m);
if (is_prime(m)) cnt++;
}
printf("%d\n", cnt);
}
return ;
}复杂度sqrt(m),判断n次就是n * sqrt(m);
sol2:新get到的技巧Miller-Rabin素数测试,结合了费马小定理和二次探测定理,可以更高效的判断素数,存在误判可能,不过误判可能非常小,可以忽略不计;
- Miller-Rabin素数测试
#include "bits/stdc++.h"
using namespace std;
int quick_pow(int n, int k, int p) {
int ans = ;
while (k) {
if (k & ) ans = 1LL * ans * n % p;
n = 1LL * n * n % p;
k >>= ;
}
return ans;
}
bool is_prime(int n) {
// if (n < 2) return false;
int s = , t = n - ;
while (!(t & )) s++, t >>= ;
for (int i = ; i <= ; i++) {
int a = rand() % (n - ) + ;
int k = quick_pow(a, t, n);
for (int j = ; j <= s; j++) {
int x = 1LL * k * k % n;
if (x == && k != && k != n - ) return false;
k = x;
}
if (k != ) return false;
}
return true;
}
int main() {
int n, m;
srand(time(NULL));
while (~scanf("%d", &n)) {
int cnt = ;
for (int i = ; i <= n; i++) {
scanf("%d", &m);
if (is_prime(m)) cnt++;
}
printf("%d\n", cnt);
}
return ;
}复杂度logm,判断n次就是n * log(m);
附加一个用于 LL 范围素数测试的模板:s
- Miller-Rabin素数测试 LL 范围模板
typedef long long LL;
LL quick_mul(LL n, LL k, LL p) {
LL ans = ;
while (k) {
if (k & ) ans = (ans + n) % p;
n = (n + n) % p;
k >>= ;
}
return ans;
}
LL quick_pow(LL n, LL k, LL p) {
LL ans = ;
while (k) {
if (k & ) ans = quick_mul(ans, n, p);
n = quick_mul(n, n, p);
k >>= ;
}
return ans;
}
bool is_prime(LL n) {
if (n < ) return false;
LL s = , t = n - ;
while (!(t & )) s++, t >>= ;
for (int i = ; i <= ; i++) {
LL a = rand() % (n - ) + ;
LL k = quick_pow(a, t, n);
for (int j = ; j <= s; j++) {
LL x = quick_mul(k, k, n);
if (x == && k != && k != n - ) return false;
k = x;
}
if (k != ) return false;
}
return true;
}大致差不多,为了防止爆 LL 加了一个快速积用于乘, 所以复杂度变成了log(m) * log(m)
HDU-2138-How many prime numbers(Miller-Rabin新解法)的更多相关文章
- HDOJ(HDU) 2138 How many prime numbers(素数-快速筛选没用上、)
Problem Description Give you a lot of positive integers, just to find out how many prime numbers the ...
- HDU 2138 How many prime numbers(Miller_Rabin法判断素数 【*模板】 用到了快速幂算法 )
How many prime numbers Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/O ...
- HDU 2138 How many prime numbers
米勒罗宾素数测试: /* if n < 1,373,653, it is enough to test a = 2 and 3. if n < 9,080,191, it is enoug ...
- HDU 2138 How many prime numbers (判素数,米勒拉宾算法)
题意:给定一个数,判断是不是素数. 析:由于数太多,并且太大了,所以以前的方法都不适合,要用米勒拉宾算法. 代码如下: #include <iostream> #include <c ...
- 【HDU】2138 How many prime numbers
http://acm.hdu.edu.cn/showproblem.php?pid=2138 题意:给n个数判断有几个素数.(每个数<=2^32) #include <cstdio> ...
- hdu 5108 Alexandra and Prime Numbers(水题 / 数论)
题意: 给一个正整数N,找最小的M,使得N可以整除M,且N/M是质数. 数据范围: There are multiple test cases (no more than 1,000). Each c ...
- hdu 5108 Alexandra and Prime Numbers
数论题,本质是求出n的最大质因子 #include<time.h> #include <cstdio> #include <iostream> #include&l ...
- HDU 3864 D_num Miller Rabin 质数推断+Pollard Rho大整数分解
链接:http://acm.hdu.edu.cn/showproblem.php? pid=3864 题意:给出一个数N(1<=N<10^18).假设N仅仅有四个约数.就输出除1外的三个约 ...
- POJ1811- Prime Test(Miller–Rabin+Pollard's rho)
题目大意 给你一个非常大的整数,判断它是不是素数,如果不是则输出它的最小的因子 题解 看了一整天<初等数论及其应用>相关部分,终于把Miller–Rabin和Pollard's rho这两 ...
- poj 1811 Pallor Rho +Miller Rabin
/* 题目:给出一个数 如果是prime 输出prime 否则输出他的最小质因子 Miller Rabin +Poller Rho 大素数判定+大数找质因子 后面这个算法嘛 基于Birthday Pa ...
随机推荐
- UML-逻辑架构精化
向下请求:Facade模式 向上返回:观察者模式 不局限于上图中指定的层使用相应模式,其他层也可以使用. 另外,尽量不要出现“公共业务模块”,设计时尽量做好系统拆分.否则,一旦修改公共代码,可能会影响 ...
- Redis的数据结构和对象。
一.简单动态字符串(simple dynamic string--SDS) Redis使用SDS表示字符串值,键值对都用SDS实现.SDS中的字符数组buf以空字符串结尾,好处是可以直接重用一部分C字 ...
- Ribbon使用及其客户端负载均衡实现原理分析
1.ribbon负载均衡测试 (1)consumer工程添加依赖 <dependency> <groupId>org.springframework.cloud</gro ...
- Go mod graphql-go 的 Replace
现在在项目中大量的使用 graphql,但用的版本是3年前的版本. 3年前包的url:github.com/neelance/graphql-go 现在的url:github.com/graph-go ...
- Python笔记_第四篇_高阶编程_进程、线程、协程_3.进程vs线程
1.多任务的实现原理: 通常我们会设计Mater-Workder模式,Master负责分配任务,Worker负责执行任务,因此多任务环境下,通常是一个Master,多个Worker 2.多进程: 主进 ...
- 杂记 -- 关于less在vue项目中的使用
1.安装less,less-loader npm install less less-loader --save 2.配置wepack.js(vue3+版本中不用自己设置) //添加less路径模块 ...
- InnoDB和MyISAM区别总结
原来是MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持. MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持,而InnoDB提供事务支持已经外部键等 ...
- Tkinter控件
1.顶层(Toplevel) Toplevel为其他控件提供单独的容器.共有四种类型(1)主顶层,作为根被应用,应该就是root(2)子顶层,依赖于根,根破坏,子顶层也被破坏(3)临时顶层,画在父顶层 ...
- win32框架
win32的框架 1.入口函数 2.窗口注册类信息 3.窗口创建 4.显示窗口 5.更新窗口 6.消息循环 7.入口函数结束 WNDCLASSEX wcex;窗口类结构 wcex.cbSize = s ...
- js变量的相关要点
如果变量在函数内没有声明(没有使用 var 关键字),该变量为全局变量. JavaScript 变量生命周期在它声明时初始化. 局部变量在函数执行完毕后销毁. 全局变量在页面关闭后销毁.