poj 1811 Prime Test【 随机素数测试与大数分解】

这是一个关于判断大整数是否为素数的问题,需要在限定时间内给出结果。题目提供了一组测试用例,每个用例包含一个不超过254的整数。如果该数是素数,则输出"Prime",否则输出其最小的质因数。示例输入包括2个测试用例,5和10,对应的输出分别是"Prime"和2。
摘要由CSDN通过智能技术生成

Prime Test
Time Limit: 6000MS Memory Limit: 65536K
Total Submissions: 29925 Accepted: 7631
Case Time Limit: 4000MS
Description

Given a big integer number, you are required to find out whether it’s a prime number.
Input

The first line contains the number of test cases T (1 <= T <= 20 ), then the following T lines each contains an integer number N (2 <= N < 254).
Output

For each test case, if N is a prime number, output a line containing the word “Prime”, otherwise, output a line containing the smallest prime factor of N.
Sample Input

2
5
10
Sample Output

Prime
2
Source

POJ Monthly

直接套bin神的板子。

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<time.h>
#include<iostream>
#include<string.h>
#include<math.h>
#include<algorithm>

using namespace std;

//****************************************************************
// Miller_Rabin 算法进行素数测试
//速度快,而且可以判断 < 2^63的数
//****************************************************************
const int S = 10;//随机算法判定次数,S越大,判错概率越小 一般8-10足够


//计算 (a*b)%c.   a,b都是long long的数,直接相乘可能溢出的
//  a,b,c <2^63
long long mult_mod(long long a, long long b, long long c)
{
    a %= c;
    b %= c;
    long
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值