[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. Oracle 11g 新特性 – HM(Hang Manager)简介

    在这篇文章中我们会对oracle 11g 新特性—hang 管理器(Hang Manager) 进行介绍.我们需要说明,HM 只在RAC 数据库中存在. 在我们诊断数据库问题的时候,经常会遇到一些数据 ...

  2. UVA 1600 Patrol Robert 巡逻机器人 (启发搜索BFS)

    非常适合A*的一道题. 比普通的迷宫问题加一个信息k表示当前穿过的障碍物的数量. #include<cstdio> #include<cstring> #include< ...

  3. 使用ErrorProvider组件验证文本框输入

    实现效果: 知识运用: ErrorProvider组件的BlinkStyle属性 //指示错误图标的闪烁时间 public ErrorBlinkStyle BlinkStyle{ get;set; } ...

  4. 2018.4.28 基于java的聊天系统(带完善)

    Java聊天系统 1.Socket类 Socket(InetAddress address, int port) 创建一个流套接字并将其连接到指定 IP 地址的指定端口号. Socket(String ...

  5. Redis的安装以及spring整合Redis时出现Could not get a resource from the pool

    Redis的下载与安装 在Linux上使用wget http://download.redis.io/releases/redis-5.0.0.tar.gz下载源码到指定位置 解压:tar -xvf ...

  6. Cookie中存放数据l加密解密的算法

    public class CookieUtil { /** * * @param response HttpServletResponse类型的响应 * @param cookie 要设置httpOn ...

  7. oracle系統表、數據字典介紹與日常問題診斷

    oracle系統表.數據字典介紹與日常問題診斷 數據字典是由唯讀的table和view組成的,產生於$oracle_home\rdbms\admin\catalog.sql.裡面儲存Oracle資料庫 ...

  8. 自行实现一个简易RPC框架

    10分钟写一个RPC框架 1.RpcFramework package com.alibaba.study.rpc.framework; import java.io.ObjectInputStrea ...

  9. java实现验证码功能

    java实现验证码功能 通过java代码实现验证码功能的一般思路: 一.通过java代码生成一张验证码的图片,将验证码的图片保存到项目中的指定文件中去,代码如下: package com.util; ...

  10. 使用powershell批量更新git仓库

    Get-ChildItem D:\GitHub\NetCore | ForEach-Object -Process{ cd $_.name; git pull; cd ../ }