当前位置: 首页 > news >正文

洛谷 P11961 [GESP202503 五级] 原根判断-提高+/省选-

题目背景

截止 2025 年 3 月,本题可能超出了 GESP 考纲范围。在该时间点下,原根是 NOI 大纲 8 级知识点(NOI 级),而相对简单的无需原根知识的做法中,使用的费马小定理与欧拉定理也属于 NOI 大纲 7 级知识点(提高级),且均未写明于 GESP 大纲中。需要注意,GESP 大纲和 NOI 大纲是不同的大纲。

若对题目中原根这一概念感兴趣,可以学习完成 【模板】原根。

题目描述

小 A 知道,对于质数 ppp 而言,ppp 的原根 ggg 是满足以下条件的正整数:

  • 1<g<p1<g<p1<g<p
  • gp−1modp=1g^{p-1}\bmod{p}=1gp1modp=1
  • 对于任意 1≤i<p−11\le i<p-11i<p1 均有 gimodp≠1g^i\bmod{p}\neq1gimodp=1

其中 amodpa\bmod{p}amodp 表示 aaa 除以 ppp 的余数。

小 A 现在有一个整数 aaa,请你帮他判断 aaa 是不是 ppp 的原根。

输入格式

第一行,一个正整数 TTT,表示测试数据组数。

每组测试数据包含一行,两个正整数 a,pa,pa,p

输出格式

对于每组测试数据,输出一行,如果 aaappp 的原根则输出 Yes,否则输出 No

输入输出样例 #1

输入 #1

3
3 998244353
5 998244353
7 998244353

输出 #1

Yes
Yes
No

说明/提示

数据范围

对于 40%40\%40% 的测试点,保证 3≤p≤1033\le p\le10^33p103

对于所有测试点,保证 1≤T≤201\le T\le201T203≤p≤1093\le p\le10^93p1091<a<p1<a<p1<a<pppp 为质数。

solution

根据费马小定理 gp−1modp=1g^{p-1}\bmod{p}=1gp1modp=1 恒成立,如果gtmodp=1g^{t}\bmod{p}=1gtmodp=1
则 t 是 p - 1的因子,所以只需要判断 p - 1 的因子即可

代码

#include <iostream>
#include "bit"
#include "vector"
#include "unordered_set"
#include "set"
#include "queue"
#include "algorithm"
#include "bitset"using namespace std;int n, a, p, k;int main() {cin >> n;for (int i = 0; i < n; i++) {cin >> a >> p;long long x = a;for (k = 2; k * k <= p - 1; k++) {if((p - 1) % k == 0){int y = (p - 1) / k;x = x * a % p; // a ^ y = ? 1if(x == 1){break;}// a ^ k = ? 1long long t = 1, z = a;while (y){if(y & 1) t = t * z % p;z = z * z % p;y /= 2;}if(t == 1){break;}}}if(k * k > p - 1) cout << "Yes\n";else cout << "No\n";}}

结果

在这里插入图片描述

http://www.lryc.cn/news/586169.html

相关文章:

  • 【设计模式】单例模式 饿汉式单例与懒汉式单例
  • 玩转rhel9 Apache
  • 关于两种网络攻击方式XSS和CSRF
  • 剑指offer57_和为S的两个数字
  • script中crossorigin=“anonymous“是什么意思
  • Redis专题总结
  • 构建AI Agent的完整实战指南:从邮件助手案例看6步落地方法
  • docker基础与常用命令
  • Linux之Zabbix分布式监控篇(一)
  • Elasticsearch 的 `modules` 目录
  • Git常用命令一览
  • 中德英法西五语氛围刷题第一集:HTML命名空间CSS处理
  • Python问题记录`No module named ‘matplotlib‘` 问题解决方案
  • 苍穹外卖项目日记(day05)
  • UI前端大数据可视化实战策略分享:如何设计符合用户认知的数据可视化流程?
  • 以数据为核心,以业务为导向,漫谈数据可视化应用
  • 上门服务APP开发源码商业模式设计与功能架构解析
  • QCustomPlot绘制交互图
  • Django母婴商城项目实践(四)
  • JavaSE 01 类和对象|继承多态
  • Java_Springboot技术框架讲解部分(一)
  • 【C/C++】迈出编译第一步——预处理
  • HCL模拟器的正确开启(Win11不兼容HCL)
  • CVPR2025 Mamba系列
  • 【读书笔记】《C++ Software Design》第二章:The Art of Building Abstractions
  • 使用python 实现一个http server
  • Elasticsearch 线程池
  • MIG_IP核的时钟系统
  • 使用 Java 开发大数据应用:Hadoop 与 Java API 的结合
  • Linux中使用快捷方式加速SSH访问