POJ 3641 素数打表+快速幂 简单题

给出2个数,p和a,2<p<=1e9,1<a<p

若p满足下面2个条件,输出yes,否则输出no

1.p不是素数

2.有a^p=a(mod p)

 

先判断第一个条件:

本来想用一个数组is_prime[i]表示i是不是素数的,明显,这里p太大,数组开不下

若p不是素数的话,

则p必有p=b*c,其中b<=c,

则(sqrt(p))^2=b*c,则b<=sqrt(p)<=10^4.5<10^5

所以若在10^5内存在数b满足b<p&&p%b==0,说明p不是素数

进一步,只要验证10^5存在素数b1满足b1<p&&p%b1==0,说明p不是素数,即满足第一个条件

所以只要把10^5内的所有素数找出来,放在数组prime里面,对于p,遍历一边即可,注意:prime[i]>=p时,要break

 

若满足了第一个条件,验证第二个条件,快速幂即可。

 

 1 #include<cstdio>
 2 #include<cstring>
 3 #include<cmath>
 4 
 5 using namespace std;
 6 
 7 #define LL long long
 8 
 9 const int maxn=1e5;
10 bool is_prime[maxn];
11 int prime[maxn>>1];
12 
13 int init_prime()
14 {
15     int i;
16     int tot=1;
17     int e=(int)(sqrt(0.0+maxn)+1);
18     memset(is_prime,true,sizeof is_prime);
19     is_prime[1]=false;
20     is_prime[2]=true;
21     prime[tot++]=2;
22     for(i=4;i<maxn;i+=2)
23         is_prime[i]=false;
24     for(i=3;i<e;i+=2)
25     {
26         if(is_prime[i])
27         {
28             prime[tot++]=i;
29             int s;
30             for(int j=i*i,s=2*i;j<maxn;j+=s)
31                 is_prime[j]=false;
32         }
33     }
34     for(;i<maxn;i+=2)
35     {
36         if(is_prime[i])
37             prime[tot++]=i;
38     }
39     return tot;
40 }
41 
42 LL quick_pow(LL a,LL p)
43 {
44     LL mod=p;
45     LL ret=1;
46     while(p>0)
47     {
48         if(p&1)
49             ret=ret*a%mod;
50         a=a*a%mod;
51         p>>=1;
52     }
53     return ret;
54 }
55 
56 void solve(int tot,LL p,LL a)
57 {
58     bool flag=false;
59     for(int i=1;i<tot;i++)
60     {
61         if(prime[i]>=p)
62             break;
63         if(p%prime[i]==0)
64         {
65             flag=true;
66             break;
67         }
68     }
69     if(!flag)
70     {
71         printf("no\n");
72         return ;
73     }
74     LL ret=quick_pow(a,p);
75     if(ret%p==a%p)
76     {
77         printf("yes\n");
78     }
79     else
80     {
81         printf("no\n");
82     }
83     return ;
84 }
85 
86 int main()
87 {
88     LL p,a;
89     int tot=init_prime();
90     while(scanf("%lld%lld",&p,&a))
91     {
92         if(!p&&!a)
93             break;
94         solve(tot,p,a);
95     }
96     return 0;
97 }
View Code

 

转载于:https://www.cnblogs.com/-maybe/p/4695775.html

资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值