题意:

给出一个多项式,问有多少个质数\(p\)使得\(p\;|\;f(x)\),不管\(x\)取何值

思路:

首先所有系数的\(gcd\)的质因子都是可以的。

再考虑一个结论,如果在\(\bmod p\)意义下,多项式中存在\((x^p - x)\)这个因式,那么这个质数\(p\)也是可以的

显然\(p \leq n\),那么我们只要枚举每个\(\leq n\)的质数,做模\(p\)意义下的多项式除法,判断余数是否为\(0\)即可。

证明:

  • 充分性:考虑\(p\;|\;f(x)\),即\(f(x) = kp\),即在\(\bmod p\)意义下,\(f(x) = 0\),根据欧拉定理,分两种情况讨论

    • \(x < p\),又因为\(p\)是质数,那么显然有\((x, p) = 1\),那么\(x^{p - 1} \equiv 1 \pmod p\),有\(x^{p} - x \equiv 0 \pmod p\)
    • \(x \geq p\),如果\(gcd(x, p)\)不为\(1\),那么显然有\(gcd(x, p) = p\),那么已经满足\(p\;|\;f(x)\),否则套用欧拉定理
  • 必要性:如果\(p\;|\;f(x)\),那么\(0, 1, \cdots, p - 1\)必然为\(f(x)\)的一个根,那么\(f(x)\)有因式\(x(x - 1)(x - 2)\cdots(x - (p - 1))\)。我们考虑这个因式与\(x^p - x\)是等价的,如果不是等价的,那么作差之后,最高次变为\(p - 1\),而根的个数却有\(p\)个,显然矛盾
#include <bits/stdc++.h>
using namespace std; #define N 10010
int n, a[N], b[N];
bool isprime(int x) {
for (int i = 2; 1ll * i * i <= x; ++i) {
if (x % i == 0) {
return false;
}
}
return true;
}
int gcd(int a, int b) {
return b ? gcd(b, a % b) : a;
}
bool ok(int p) {
if (a[0] % p) {
return false;
}
for (int i = 0; i <= n; ++i) {
b[i] = a[i];
}
for (int i = n; i >= p - 1; --i) {
(b[i - (p - 1)] += b[i]) %= p;
b[i] = 0;
}
for (int i = 0; i <= n; ++i) {
if (b[i] % p) {
return false;
}
}
return true;
} int main() {
while (scanf("%d", &n) != EOF) {
int G = 0;
for (int i = 0; i <= n; ++i) {
scanf("%d", a + i);
G = gcd(G, abs(a[i]));
}
reverse(a, a + 1 + n);
vector <int> res;
for (int i = 2; 1ll * i * i <= G; ++i) {
if (G % i == 0) {
res.push_back(i);
while (G % i == 0) {
G /= i;
}
}
}
if (G > 1) {
res.push_back(G);
}
for (int i = 2; i <= n; ++i) {
if (isprime(i) && ok(i)) {
res.push_back(i);
}
}
sort(res.begin(), res.end());
res.erase(unique(res.begin(), res.end()), res.end());
for (auto it : res) {
printf("%d\n", it);
}
// puts("------------");
}
return 0;
}

最新文章

  1. Linux 下如何安装软件
  2. Android -- Apk安装简诉
  3. [自动运维]ant脚本打包,上传文件到指定服务器,并部署
  4. Android 图片的放大缩小拖拉
  5. 【转】MYSQL入门学习之八:数据库及表的基本操作
  6. What is the Database Initialization Parameter That is Associated to an ORA-32004 Error ?
  7. c/c++ 编译器内存对齐问题
  8. 1.5.1 Analyzers,Tokenizers,Filters概述
  9. Asp.net MVC 4 Attributes特性
  10. 动态调用DLL函数有时正常,有时报Access violation的异常
  11. THUSC2015
  12. MVC中使用Hangfire按秒执行任务
  13. FreeNAS:创建 CIFS 匿名共享
  14. JDK环境安装步骤
  15. 第50节:Java的当中的泛型
  16. 深入理解session机制
  17. 简约时尚商城wordpress主题-storefront
  18. 关于utf8mb4的学习了解笔记
  19. SCWS 中文分词_测试成功
  20. Code Fragment-UI加载策略之-可视者优先加载

热门文章

  1. IOS 6 和 IOS7 UITableViewCell上添加控件的获取
  2. 画面渲染:实时渲染(Real-time Rendering)、离线渲染(Offline Rendering)[转]
  3. AppScan扫描建议 问题集
  4. tomcat内存溢出:PermGen space解决方法
  5. Druid的Segment Balance及其代价计算函数分析
  6. 【问题收录】Ubuntu14.04连接两个双显示器失败的解决方案
  7. Myers–Briggs_Type_Indicator 迈尔斯布里格斯类型指标(MBTI)
  8. $w=$mysqli-&gt;query($sql);
  9. h5地理位置API
  10. django model field validator 设置