Atcoder Tenka1 Programmer Contest 2019 E - Polynomial Divisors
题意:
给出一个多项式,问有多少个质数\(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的更多相关文章
- Atcoder Tenka1 Programmer Contest 2019 题解
link 题面真简洁 qaq C Stones 最终一定是连续一段 . 加上连续一段 # .直接枚举断点记录前缀和统计即可. #include<bits/stdc++.h> #define ...
- Atcoder Tenka1 Programmer Contest 2019题解
传送门 \(C\ Stones\) 最后肯定形如左边一段白+右边一段黑,枚举一下中间的断点,预处理一下前缀和就可以了 int main(){ // freopen("testdata.in& ...
- Atcoder Tenka1 Programmer Contest 2019
C 签到题,f[i][0/1]表示以i结尾最后一个为白/黑的最小值,转移显然. #include<bits/stdc++.h> using namespace std; ; ]; char ...
- Atcoder Tenka1 Programmer Contest 2019 D Three Colors
题意: 有\(n\)个石头,每个石头有权值,可以给它们染'R', 'G', 'B'三种颜色,如下定义一种染色方案为合法方案: 所有石头都染上了一种颜色 令\(R, G, B\)为染了'R', 染了'G ...
- 【AtCoder】Tenka1 Programmer Contest 2019
Tenka1 Programmer Contest 2019 C - Stones 题面大意:有一个01序列,改变一个位置上的值花费1,问变成没有0在1右边的序列花费最少多少 直接枚举前i个都变成0即 ...
- Atcoder Tenka1 Programmer Contest D: IntegerotS 【思维题,位运算】
http://tenka1-2017.contest.atcoder.jp/tasks/tenka1_2017_d 给定N,K和A1...AN,B1...BN,选取若干个Ai使它们的或运算值小于等于K ...
- Atcoder Tenka1 Programmer Contest C C - 4/N
http://tenka1-2017.contest.atcoder.jp/tasks/tenka1_2017_c 我怀疑我是不是智障.... 本来一直的想法是能不能构造出答案,把N按奇偶分,偶数好办 ...
- Tenka1 Programmer Contest 2019
C:即要使前一部分为白色后一部分为黑色,枚举分割点前缀和计算答案取min即可. #include<bits/stdc++.h> using namespace std; #define l ...
- Tenka1 Programmer Contest 2019 D - Three Colors
Three Colors 思路:dp 设sum为所有边的总和 不能组成三角形的情况:某条边长度>=ceil(sum/2),可以用dp求出这种情况的方案数,然后用总方案数减去就可以求出答案. 注意 ...
随机推荐
- Visual Studio 2013编译Mozilla NPAPI 示例注意事项
1.Platform Toolset设置Visual Studio 2013 - Windows XP (v120_xp). 2.Character Set设置Use Multi-Byte Chara ...
- 对Java中使用两个大括号进行初始化的理解
最近重读Java 编程思想,读到有关实例化代码块儿 的内容,使我对于使用两个大括号进行初始化有了更深的理解. 实例化代码块儿: 和静态代码块儿的概念相对应,静态代码块儿是static 关键字 + 大括 ...
- Android短信发送器_08
1.string xml代码 <?xml version="1.0" encoding="utf-8"?> <resources> &l ...
- 【BZOJ1417】Pku3156 Interconnect 记忆化搜索
[BZOJ1417]Pku3156 Interconnect Description 给出无向图G(V, E). 每次操作任意加一条非自环的边(u, v), 每条边的选择是等概率的. 问使得G连通的期 ...
- [深入浅出Cocoa]iOS网络编程之Socket
http://blog.csdn.net/kesalin/article/details/8798039 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] [深入浅出Co ...
- spring配置多视图解析器
最近做一个小项目(移动端),自己搭了个简单的SSM框架(spring + spring MVC + Mybitis),展示层本来选用的是jsp,各方便都已经搭建好,结果发现有些页面需要用到H5的一些功 ...
- SSH教程从零打造在线网盘系统前言&目录
本系列教程内容提要 本系列教程是一个学习教程,是关于Java工程师的SSH(Struts2+Spring+Hibernate)系列教程,本教程将会分为四个部分和大家一同打造一个在线网盘系统,由于教程是 ...
- R数据可视化手册学习——条形图
1. 绘制简单条形图 # 使用ggplot2和gcookbook library(ggplot2); library(gcookbook) g <- ggplot(data = pg_mean, ...
- Solr学习笔记之4、Solr配置文件简介
Solr学习笔记之4.Solr配置文件简介 摘自<Solr in Action>. 1. solr.xml – Defines one or more cores per Solr ser ...
- 2018牛客网暑期ACM多校训练营(第二场) J - farm - [随机数哈希+二维树状数组]
题目链接:https://www.nowcoder.com/acm/contest/140/J 时间限制:C/C++ 4秒,其他语言8秒 空间限制:C/C++ 262144K,其他语言524288K ...