题意:

给出一个多项式,问有多少个质数\(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;
}

Atcoder Tenka1 Programmer Contest 2019 E - Polynomial Divisors的更多相关文章

  1. Atcoder Tenka1 Programmer Contest 2019 题解

    link 题面真简洁 qaq C Stones 最终一定是连续一段 . 加上连续一段 # .直接枚举断点记录前缀和统计即可. #include<bits/stdc++.h> #define ...

  2. Atcoder Tenka1 Programmer Contest 2019题解

    传送门 \(C\ Stones\) 最后肯定形如左边一段白+右边一段黑,枚举一下中间的断点,预处理一下前缀和就可以了 int main(){ // freopen("testdata.in& ...

  3. Atcoder Tenka1 Programmer Contest 2019

    C 签到题,f[i][0/1]表示以i结尾最后一个为白/黑的最小值,转移显然. #include<bits/stdc++.h> using namespace std; ; ]; char ...

  4. Atcoder Tenka1 Programmer Contest 2019 D Three Colors

    题意: 有\(n\)个石头,每个石头有权值,可以给它们染'R', 'G', 'B'三种颜色,如下定义一种染色方案为合法方案: 所有石头都染上了一种颜色 令\(R, G, B\)为染了'R', 染了'G ...

  5. 【AtCoder】Tenka1 Programmer Contest 2019

    Tenka1 Programmer Contest 2019 C - Stones 题面大意:有一个01序列,改变一个位置上的值花费1,问变成没有0在1右边的序列花费最少多少 直接枚举前i个都变成0即 ...

  6. Atcoder Tenka1 Programmer Contest D: IntegerotS 【思维题,位运算】

    http://tenka1-2017.contest.atcoder.jp/tasks/tenka1_2017_d 给定N,K和A1...AN,B1...BN,选取若干个Ai使它们的或运算值小于等于K ...

  7. Atcoder Tenka1 Programmer Contest C C - 4/N

    http://tenka1-2017.contest.atcoder.jp/tasks/tenka1_2017_c 我怀疑我是不是智障.... 本来一直的想法是能不能构造出答案,把N按奇偶分,偶数好办 ...

  8. Tenka1 Programmer Contest 2019

    C:即要使前一部分为白色后一部分为黑色,枚举分割点前缀和计算答案取min即可. #include<bits/stdc++.h> using namespace std; #define l ...

  9. Tenka1 Programmer Contest 2019 D - Three Colors

    Three Colors 思路:dp 设sum为所有边的总和 不能组成三角形的情况:某条边长度>=ceil(sum/2),可以用dp求出这种情况的方案数,然后用总方案数减去就可以求出答案. 注意 ...

随机推荐

  1. 【CF884F】Anti-Palindromize 费用流

    [CF884F]Anti-Palindromize 题意:定义一个串是反回文的,当且仅当对于1<=i<=len,$a_i!=a_{len-i+1}$. 现在给出一个长度为n的串S(n是偶数 ...

  2. [APP] Android 开发笔记 004-Android常用基本控件使用说明

    TextView 文本框 EditText控件 Button 与 ImageButton ImageView RadioButton CheckBox复选框 TextView 文本框 ,用于显示文本的 ...

  3. springMVC 报错:Unknown return value type: java.lang.Integer

    controller层返回值类型为Integer,运行报错: Unknown return value type: java.lang.Integer 解决办法:在此方法上写上注解 @Response ...

  4. 《C与指针》——高级指针话题

    指针真是让人又爱又恨..... 首先还是先来看一下C语言中的高级指针声明.不要被表面迷惑最重要. /* ** <C和指针>——高级指针话题 */ int i; //定义一个整型变量 int ...

  5. 【转】单片机中volatile定义的作用详解

    传送门:http://www.eeworld.com.cn/mcu/2011/0411/article_3928.html 一个定义为volatile的变量是说这变量可能会被意想不到地改变,这样,编译 ...

  6. 8.22js前端!

    2018-8-22 19:15:19 前端还有一部分就学完了预计这一星期赶一下就可以结束 然后愉快地进行Django框架!!!! 今天中午和呆呆一块吃的大盘鸡,下午和老表我们三个去了日月湖狼了一下午! ...

  7. 计蒜客 30996 - Lpl and Energy-saving Lamps - [线段树][2018ICPC南京网络预赛G题]

    题目链接:https://nanti.jisuanke.com/t/30996 During tea-drinking, princess, amongst other things, asked w ...

  8. Zookeeper简介及单机、集群模式搭建

    1.zookeeper简介 一个开源的分布式的,为分布式应用提供协调服务的apache项目. 提供一个简单的原语集合,以便于分布式应用可以在它之上构建更高层次的同步服务. 设计非常易于编程,它使用的是 ...

  9. N-N

    ---情景--- 关系:角色N-N区域 基础表:角色表.区域表 关系表:主键-角色id-区域id集 ---需求--- 实现“单个区域勾选角色”且不借助与非SQL脚本(php etc)遍历 ---疑惑- ...

  10. 单例模式:Qt本身就提供了专门的宏 Q_GLOBAL_STATIC 通过这个宏不但定义简单,还可以获得线程安全性

    标题起的是有点大 主要是工作和学习中,遇到些朋友,怎么说呢,代码不够Qt化 可能是由于他们一开始接触的是 Java MFC 吧 接触 Qt 7个年头了 希望我的系列文章能抛砖引玉吧 单例模式 很多人洋 ...