Submission #6871256
Source Code Expand
#include <bits/stdc++.h>
#define rep(i, n) for (ll i = 0; i < (n); i++)
#define rep2(i, a, b) for (ll i = (a); i < (b); i++)
typedef uint64_t ull;
typedef int64_t ll;
typedef std::pair<ll, ll> PLL;
using namespace std;
std::vector<ll> fac(510000, 1), finv(510000, 1), inv(510000, 1);
void c4_init(ll m) {
for (ll i = 2; i < 510000; i++) {
fac[i] = fac[i - 1] * i % m;
inv[i] = m - inv[m%i] * (m / i) % m;
finv[i] = finv[i - 1] * inv[i] % m;
}
}
ll c4(ll n, ll k, ll m) {
if (n < k) return 0;
if (n < 0 || k < 0) return 0;
return fac[n] * (finv[k] * finv[n - k] % m) % m;
}
signed main() {
ll p;
cin>>p;
vector<ll> a(p-1);
rep(i,p)
cin>>a[i];
c4_init(p);
vector<ll> b(p-1,0);
rep(i,p){
if (a[i] == 0)
continue;
(b[0] += 1) %= p;
ll pw = 1;
for (ll j=p-1; j>=0; j--) {
(b[j] += p*p - pw * c4(p-1, j, p)) %= p;
(pw *= p-i) %= p;
}
}
rep(i,p){
cout<<b[i]<<(i!=p-1 ? " ":"");
}
cout<<endl;
return 0;
}
Submission Info
| Submission Time | |
|---|---|
| Task | F - Polynomial Construction |
| User | bobuhiro11 |
| Language | C++14 (GCC 5.4.1) |
| Score | 600 |
| Code Size | 1067 Byte |
| Status | AC |
| Exec Time | 467 ms |
| Memory | 12416 KiB |
Judge Result
| Set Name | Sample | All | ||||
|---|---|---|---|---|---|---|
| Score / Max Score | 0 / 0 | 600 / 600 | ||||
| Status |
|
|
| Set Name | Test Cases |
|---|---|
| Sample | a01, a02, a03 |
| All | a01, a02, a03, b04, b05, b06, b07, b08, b09, b10, b11, b12, b13, b14, b15, b16, b17, b18, b19, b20, b21, b22, b23, b24, b25, b26, b27, b28, b29, b30, b31, b32, b33, b34, b35, b36, b37, b38, b39, b40, b41, b42, b43 |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| a01 | AC | 29 ms | 12160 KiB |
| a02 | AC | 29 ms | 12160 KiB |
| a03 | AC | 29 ms | 12160 KiB |
| b04 | AC | 29 ms | 12160 KiB |
| b05 | AC | 29 ms | 12160 KiB |
| b06 | AC | 29 ms | 12160 KiB |
| b07 | AC | 30 ms | 12288 KiB |
| b08 | AC | 467 ms | 12288 KiB |
| b09 | AC | 467 ms | 12288 KiB |
| b10 | AC | 467 ms | 12288 KiB |
| b11 | AC | 30 ms | 12288 KiB |
| b12 | AC | 30 ms | 12288 KiB |
| b13 | AC | 248 ms | 12288 KiB |
| b14 | AC | 248 ms | 12288 KiB |
| b15 | AC | 92 ms | 12288 KiB |
| b16 | AC | 404 ms | 12288 KiB |
| b17 | AC | 248 ms | 12288 KiB |
| b18 | AC | 248 ms | 12288 KiB |
| b19 | AC | 244 ms | 12288 KiB |
| b20 | AC | 331 ms | 12288 KiB |
| b21 | AC | 423 ms | 12288 KiB |
| b22 | AC | 444 ms | 12288 KiB |
| b23 | AC | 466 ms | 12288 KiB |
| b24 | AC | 465 ms | 12288 KiB |
| b25 | AC | 467 ms | 12288 KiB |
| b26 | AC | 255 ms | 12288 KiB |
| b27 | AC | 163 ms | 12288 KiB |
| b28 | AC | 75 ms | 12416 KiB |
| b29 | AC | 54 ms | 12288 KiB |
| b30 | AC | 33 ms | 12288 KiB |
| b31 | AC | 32 ms | 12288 KiB |
| b32 | AC | 30 ms | 12288 KiB |
| b33 | AC | 29 ms | 12160 KiB |
| b34 | AC | 29 ms | 12160 KiB |
| b35 | AC | 211 ms | 12288 KiB |
| b36 | AC | 351 ms | 12288 KiB |
| b37 | AC | 131 ms | 12288 KiB |
| b38 | AC | 47 ms | 12288 KiB |
| b39 | AC | 29 ms | 12160 KiB |
| b40 | AC | 92 ms | 12288 KiB |
| b41 | AC | 31 ms | 12160 KiB |
| b42 | AC | 47 ms | 12288 KiB |
| b43 | AC | 45 ms | 12288 KiB |