求原根_模12的原根

求原根_模12的原根今天学了数论。。。求原根真的好暴力设模数为p我们把p−1p−1p-1分解质因数,对于每一个2≤i≤p−12≤i≤p−12\leqi\leqp-1,判断an−1pi%pan−1pi%pa^{n-1\overp_i}\%p是否为1,如果是,那么这个数就不是原根,否则就是ACCode#include<cstdio>#include<iostre

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

今天学了数论。。。求原根真的好暴力
设模数为p,
我们把 p − 1 p-1 p1分解质因数, p 1 , p 2 … p m p_1,p_2 \ldots p_m p1,p2pm对于每一个 2 ≤ i ≤ p − 1 2 \leq i \leq p-1 2ip1 ,判断 i p − 1 p j % p i^{p-1 \over p_j} \%p ipjp1%p是否为1,如果是,那么这个数就不是原根,否则就是
AC Code

#include<cstdio>
#include<iostream>
#include<cmath>
using namespace std;
int zys[50];
int p;
int o;
int n;
int ksm(int a,int c,int b)
{ 
   
	long long re=1;
	long long t=a;
	while(c)
	{ 
   
		if(c&1)re=re%b*t%b;
		t=t%b*t%b;
		c>>=1;
	}
	return re;
}
int pd(int x)
{ 
   
	for(int i=1;i<=o;i++)
	{ 
   
		if(ksm(x,(p-1)/zys[i],p)%p==1)return 0;
	}
	return 1;
}
int main()
{ 
   
	scanf("%d",&p);
	int pp=p;
	p--;
	for(int i=2;i<=sqrt(p);i++)
	{ 
   
		if(p==1)break;
		if(p%i==0)
		{ 
   
			o++;
			zys[o]=i;
			while(p%i==0)
			{ 
   
				p/=i;
			}
		}
	}
	if(p!=1)
	{ 
   
		o++;
		zys[o]=p;
	}
	p=pp;
	for(int i=2;i<p;i++)
	{ 
   
		if(pd(i))
		{ 
   
			printf("%d",i);
			break;
		}
	}	
	return 0;
} 

Jetbrains全家桶1年46,售后保障稳定

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/215435.html原文链接:https://javaforall.net

(0)
上一篇 2025年7月15日 下午10:01
下一篇 2025年7月15日 下午10:43


相关推荐

  • UNIX的常用命令

    UNIX的常用命令Unix常用命令介绍:  多命令行:“;”多行命令:“\”1、系统关闭reboot、halt/shutdown、poweroff2、passwd命令:修改系统用户密码passwd[username]3、su命令:切换系统用户su[-username]username为空表示root用户4、cat命令:将指定的文件在标准输出到显示器cat [-AbET] [文件名列表]-A      …

    2022年5月31日
    37
  • 对于三极管饱和状态的理解「建议收藏」

    对于三极管饱和状态的理解「建议收藏」对于三极管饱和状态的理解https://zhidao.baidu.com/question/172715750.html问题来源对于三极管饱和状态的理解三极管如工作在饱和状态也就是开的状态,那么就是双结正偏这是书上的解释我自己的理解是这样的:饱和状态和从放大状态转变过来的,极电结和发射结正偏是结果,而不是原因就是说,三极管首先工作在放大状态,极电结反偏,发射结正偏当基级电流增大时,一直增大到三极管的非线性区(这里指的是饱和区),注意,在这一瞬间偏置情况并未改变,也就是说依然是极电结反偏,

    2025年10月23日
    7
  • 面向对象设计原则之开闭原则

    面向对象设计原则之开闭原则开闭原则是面向对象的可复用设计的第一块基石 它是最重要的面向对象设计原则 开闭原则由 Bertrand nbsp Meyer 于 1988 年提出 其定义如下 开闭原则 Open ClosedPrinci OCP 一个软件实体应当对扩展开放 对修改关闭 即软件实体应尽量在不修改原有代码的情况下进行扩展 nbsp nbsp nbsp nbsp nbsp 在开闭原则的定义中 软件实体可以指一个软件模块

    2026年3月17日
    1
  • Python基础知识归纳「建议收藏」

    Python基础知识归纳「建议收藏」Python基础教程Python基础教程Python简介Python环境搭建Python中文编码Python基础语法Python变量类型Python运算符Python条件语句Python循环语句PythonWhile循环语句Pythonfor循环语句Python循环嵌套Pythonbreak语句Python…

    2022年10月16日
    3
  • Java基础知识总结(2021版)「建议收藏」

    前言大家好,我是素小暖,2012年毕业,2016年通过培训转行java开发,今天2021年1月9日,转行之路跌跌绊绊,蓦然回首,已经满满的4年工作经验了?但感觉知识还是相当的匮乏,没自信,也许是努力程度还不够吧。很感谢CSDN,因为是它给了我学习的动力,之前写了一篇记录CSDN博客访问量的文章,也许大家感觉很幼稚,但真的很有用,很有效果,仿佛磕了药一样,努力学习,进步。2020年,是我较为成功的一年,工作上,跳了槽,涨了工资;学习上,啃了几本名著(EffectiveJava、重构改善既.

    2022年4月7日
    41
  • 埃隆·马斯克的X计划在Grok聊天机器人的回复中引入广告,以缓解收入压力

    埃隆·马斯克的X计划在Grok聊天机器人的回复中引入广告,以缓解收入压力

    2026年3月15日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号