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

时间:2023-02-23 18:32:15

[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 &num;525&period; 「LibreOJ β Round &num;4」多项式

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

  2. &lbrack;LOJ&num;531&rsqb;「LibreOJ β Round &num;5」游戏

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

  3. &lbrack;LOJ&num;530&rsqb;「LibreOJ β Round &num;5」最小倍数

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

  4. &lbrack;LOJ&num;516&rsqb;「LibreOJ β Round &num;2」DP 一般看规律

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

  5. &lbrack;LOJ&num;515&rsqb;「LibreOJ β Round &num;2」贪心只能过样例

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

  6. &lbrack;LOJ&num;526&rsqb;「LibreOJ β Round &num;4」子集

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

  7. &lbrack;LOJ&num;522&rsqb;「LibreOJ β Round &num;3」绯色 IOI(危机)

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

  8. loj &num;547&period; 「LibreOJ β Round &num;7」匹配字符串

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

  9. loj &num;535&period; 「LibreOJ Round &num;6」花火 树状数组求逆序对&plus;主席树二维数点&plus;整体二分

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

随机推荐

  1. &lbrack;转&rsqb;MySQL 最基本的SQL语法&sol;语句

    MySQL 最基本的SQL语法/语句,使用mysql的朋友可以参考下.   DDL-数据定义语言(Create,Alter,Drop,DECLARE) DML-数据操纵语言(Select,Delete ...

  2. KendoUI系列:TabStrip

    <link href="@Url.Content("~/Content/kendo/2014.1.318/kendo.common.min.css")" ...

  3. Android WebView Memory Leak WebView内存泄漏

    在这次开发过程中,需要用到webview展示一些界面,但是加载的页面如果有很多图片就会发现内存占用暴涨,并且在退出该界面后,即使在包含该webview的Activity的destroy()方法中,使用 ...

  4. HTML--4格式布局

    一.position:fixed 锁定位置(相对于浏览器的位置),例如有些网站的右下角的弹出窗口. 示例: 二.position:absolute 1.外层没有position:absolute(或r ...

  5. PHP header&lpar;&rpar; 函数详细说明&lpar;301、404等错误设置&rpar;

    原文来自:http://www.veryhuo.com/a/view/41466.html 如果您刚刚开始学习PHP,可能有许多函数需要研究,今天我们就来学习一下PHP Header()的使用方法,更 ...

  6. 提高效率的便签By番茄时间管理 win7标签,小功能,大作用

    今日待办 把一些重要的事情,列入其中. 着重处理. 活动清单 罗列一些最近需要做的事情,不一定按照紧急重要的程度. 把活动清单中的事情,按照实际情况,安排到今日待办当中. 还有一个我喜欢的'头脑风暴' ...

  7. Vue&period;js实现拼图游戏

    Vue.js实现拼图游戏 之前写过一篇<基于Vue.js的表格分页组件>的文章,主要介绍了Vue组件的编写方法,有兴趣的可以访问这里进行阅读:http://www.cnblogs.com/ ...

  8. 《3》CentOS7&period;0&plus;OpenStack&plus;kvm云平台部署—配置Glance

    感谢朋友支持本博客,欢迎共同探讨交流.因为能力和时间有限,错误之处在所难免,欢迎指正. 假设转载.请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...

  9. Java中String字符串常量池总结

    最近到广州某建站互联网公司面试,当时面试官问假设有两个字符串String a="abc",String b = "abc";问输出a==b是true还是fals ...

  10. javascript中的立即执行函数的原理

    形如 ((function Test(a) { //code here... })('Hello')); 被称作立即执行函数. 首先需要了解的是,这并不是一种hack,这是javascript的基本语 ...