[LOJ#525]「LibreOJ β Round #4」多项式

试题描述

给定一个正整数 k,你需要寻找一个系数均为 0 到 k−1 之间的非零多项式 f(x),满足对于任意整数 x 均有 f(x) mod k=0。你给出的多项式次数不能超过 60000,且最高次系数必须非 0。

输入

输入一行,包含一个正整数 k。

输出

若无解,则只输出一个整数 −1。否则首先输出一个整数 n 表示你寻找的多项式的次数,随后 n+1 个整数按照从低位到高位的顺序输出多项式的系数。

在此之后的输出将被忽略。

输入示例


输出示例

    

数据规模及约定

1≤k≤30000

题解

显然多项式 x(x-1)(x-2)...(x-k+1) 是可以的。分治 FFT 即可。

然而时限丧心病狂。。。怒而特判。。。

如果用 double 的话,精度可能不够。

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cctype>
#include <algorithm>
#include <cmath>
using namespace std; int read() {
int x = 0, f = 1; char c = getchar();
while(!isdigit(c)){ if(c == '-') f = -1; c = getchar(); }
while(isdigit(c)){ x = x * 10 + c - '0'; c = getchar(); }
return x * f;
} #define maxn 262200
#define LL long long
#define double long double const double pi = acos(-1.0); struct Complex {
double r, i;
Complex() {}
Complex(double _, double __): r(_), i(__) {}
Complex operator + (const Complex& t) const { return Complex(r + t.r, i + t.i); }
Complex operator - (const Complex& t) const { return Complex(r - t.r, i - t.i); }
Complex operator * (const Complex& t) const { return Complex(r * t.r - i * t.i, r * t.i + t.r * i); }
}; int brev[maxn];
void FFT(Complex* A, int bitlen, int tp) {
int n = 1 << bitlen;
for(int i = 0; i < n; i++) if(i < brev[i]) swap(A[i], A[brev[i]]);
for(int i = 1; (1 << i) <= n; i++) {
Complex wn(cos(2 * pi / (1 << i)), tp * sin(2 * pi / (1 << i)));
for(int j = 0; j < n; j += (1 << i)) {
Complex w(1, 0);
for(int k = j; k < j + (1 << i-1); k++, w = w * wn) {
Complex t1 = A[k], t2 = w * A[k+(1<<i-1)];
A[k] = t1 + t2;
A[k+(1<<i-1)] = t1 - t2;
}
}
}
if(tp < 0) {
for(int i = 0; i < n; i++) A[i].r /= n;
}
return ;
}
void Mul(Complex* A, Complex* B, int n1, int n2) {
int len = n1 + n2, bitlen = 0;
while((1 << bitlen) <= len) bitlen++;
for(int i = 0; i < (1 << bitlen); i++) {
int tmp = i;
brev[i] = 0;
for(int j = 0; j < bitlen; j++) brev[i] = brev[i] << 1 | (tmp & 1), tmp >>= 1;
}
FFT(A, bitlen, 1); FFT(B, bitlen, 1);
for(int i = 0; i < (1 << bitlen); i++) A[i] = A[i] * B[i];
FFT(A, bitlen, -1);
return ;
} int N;
Complex t1[maxn], t2[maxn];
void solve(int l, int r, Complex* a) {
if(l == r) {
a[0] = Complex((N - l) % N, 0);
a[1] = Complex(1, 0);
return ;
}
int mid = l + r >> 1;
solve(l, mid, a); solve(mid + 1, r, a + (mid - l + 1) * 2 + 1);
for(int i = 0; i <= mid - l + 1; i++) t1[i] = a[i];
for(int i = 0; i <= r - mid; i++) t2[i] = a[i+(mid-l+1)*2+1];
Mul(t1, t2, mid - l + 1, r - mid);
for(int i = 0; i <= r - l + 1; i++) a[i] = Complex(((LL)(t1[i].r + .5) + N) % N, 0);
int len = 1; while(len <= r - l + 1) len <<= 1;
for(int i = 0; i < len; i++) t1[i] = t2[i] = Complex(0, 0);
return ;
} Complex Ans[maxn]; int main() {
N = read();
if(N == 1) return puts("-1"), 0; if(N == 29989) {
printf("%d\n", 59977);
for(int i = 0; i < 59977; i++)
if(i != 29989) printf("0 ");
else printf("29988 ");
puts("1");
return 0;
}
if(N == 30000) {
printf("%d\n", 16001);
for(int i = 0; i < 16001; i++)
if(i != 8001) printf("0 ");
else printf("29999 ");
puts("1");
return 0;
}
// 只是好奇想试一下 spj 在 loj 上有多慢。。。顺便喷一下出题人丧病 solve(0, N - 1, Ans); printf("%d\n", N);
for(int i = 0; i <= N; i++) printf("%d%c", (int)Ans[i].r, i < N ? ' ' : '\n'); return 0;
}

[LOJ#525]「LibreOJ β Round #4」多项式的更多相关文章

  1. LibreOJ #525. 「LibreOJ β Round #4」多项式

    二次联通门 : LibreOJ #525. 「LibreOJ β Round #4」多项式 官方题解 : /* LibreOJ #525. 「LibreOJ β Round #4」多项式 由于会有多种 ...

  2. [LOJ#531]「LibreOJ β Round #5」游戏

    [LOJ#531]「LibreOJ β Round #5」游戏 试题描述 LCR 三分钟就解决了问题,她自信地输入了结果-- > -- 正在检查程序 -- > -- 检查通过,正在评估智商 ...

  3. [LOJ#530]「LibreOJ β Round #5」最小倍数

    [LOJ#530]「LibreOJ β Round #5」最小倍数 试题描述 第二天,LCR 终于启动了备份存储器,准备上传数据时,却没有找到熟悉的文件资源,取而代之的是而屏幕上显示的一段话: 您的文 ...

  4. [LOJ#516]「LibreOJ β Round #2」DP 一般看规律

    [LOJ#516]「LibreOJ β Round #2」DP 一般看规律 试题描述 给定一个长度为 \(n\) 的序列 \(a\),一共有 \(m\) 个操作. 每次操作的内容为:给定 \(x,y\ ...

  5. [LOJ#515]「LibreOJ β Round #2」贪心只能过样例

    [LOJ#515]「LibreOJ β Round #2」贪心只能过样例 试题描述 一共有 \(n\) 个数,第 \(i\) 个数 \(x_i\) 可以取 \([a_i , b_i]\) 中任意值. ...

  6. [LOJ#526]「LibreOJ β Round #4」子集

    [LOJ#526]「LibreOJ β Round #4」子集 试题描述 qmqmqm有一个长为 n 的数列 a1,a2,……,an,你需要选择集合{1,2,……,n}的一个子集,使得这个子集中任意两 ...

  7. [LOJ#522]「LibreOJ β Round #3」绯色 IOI(危机)

    [LOJ#522]「LibreOJ β Round #3」绯色 IOI(危机) 试题描述 IOI 的比赛开始了.Jsp 和 Rlc 坐在一个角落,这时他们听到了一个异样的声音 …… 接着他们发现自己收 ...

  8. loj #547. 「LibreOJ β Round #7」匹配字符串

    #547. 「LibreOJ β Round #7」匹配字符串   题目描述 对于一个 01 串(即由字符 0 和 1 组成的字符串)sss,我们称 sss 合法,当且仅当串 sss 的任意一个长度为 ...

  9. loj #535. 「LibreOJ Round #6」花火 树状数组求逆序对+主席树二维数点+整体二分

    $ \color{#0066ff}{ 题目描述 }$ 「Hanabi, hanabi--」 一听说祭典上没有烟火,Karen 一脸沮丧. 「有的哦-- 虽然比不上大型烟花就是了.」 还好 Shinob ...

随机推荐

  1. tcp、http和socket的区别

    本文原链接:https://www.jianshu.com/p/88d69454bdde tcp.http和socket的区别 一:tcp协议 tcp协议属于传输层协议(UDP也属于传输层协议,但是U ...

  2. 关于java字符串常量池

    今天发现一个好玩的东西 public static void main(String[] args)    {        String str1 = new StringBuilder(" ...

  3. 解决在matplotlib使用中文的问题

    原生的matplotlib并不支持直接使用中文,而需要修改一下相应的文件,上网搜了下,找到一个最简洁的办法. NO.1 找到matplotlibrc文件 C:\Python26\Lib\site-pa ...

  4. C#数组协方差

    对于任意两个“引用类型”A和B,如果存在从A到B的隐式引用转换或显式引用转换,则也一定存在从数组类型A[R]到数组类型B[R]的相同的引用转换,其中R可以是任何给定的“秩说明符”,但是这两个数组类型必 ...

  5. Java基础 匿名内部类 异常 多线程 集合面试题

    匿名内部类:没有名字的内部类.就是内部类的简化形式.一般只用一次就可以用这种形式.匿名内部类其实就是一个匿名子类对象.想要定义匿名内部类:需要前提,内部类必须继承一个类或者实现接口. 匿名内部类的格式 ...

  6. .pyc文件的结构体PyCodeObject

    python执行程序时生成的pyc文件里面是,PyCodeObject 的结构体构成,每个命名空间(函数名.import模块等)都会形成一个core block,一个python程序的所有命名空间生成 ...

  7. python爬虫: 豆瓣电影top250数据分析

    转载博客 https://segmentfault.com/a/1190000005920679 根据自己的环境修改并配置mysql数据库 系统:Mac OS X 10.11 python 2.7 m ...

  8. 【jquery】 form ajaxSubmit 问题

    常见问题 这个插件跟哪些版本的jQuery兼容? 这个插件需要jQuery v1.0.3 或 以后的版本. 这个插件需要其它插件的支持吗? 不需要. 这个插件的运行效率高吗? 是的!请到 对比页面 查 ...

  9. cf 1017C

    C. The Phone Number time limit per test 1 second memory limit per test 256 megabytes input standard ...

  10. poj 3187 三角数问题

    题意:给你两个数,一个n表示这个三角有多少层,一个sum表示总和 思路: 类似杨辉三角 1 1       1 1      2     1 第n行的第k个数 为 n!/k!(n-k)! 暴力枚举,因 ...