結果
問題 | No.563 超高速一人かるた large |
ユーザー | btk |
提出日時 | 2017-08-27 15:56:23 |
言語 | C++14 (gcc 12.3.0 + boost 1.83.0) |
結果 |
WA
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 3,031 bytes |
コンパイル時間 | 1,790 ms |
コンパイル使用メモリ | 171,440 KB |
実行使用メモリ | 36,732 KB |
最終ジャッジ日時 | 2024-11-06 06:45:00 |
合計ジャッジ時間 | 5,537 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | WA | - |
testcase_01 | WA | - |
testcase_02 | AC | 16 ms
36,532 KB |
testcase_03 | WA | - |
testcase_04 | WA | - |
testcase_05 | WA | - |
testcase_06 | WA | - |
testcase_07 | WA | - |
testcase_08 | WA | - |
testcase_09 | WA | - |
testcase_10 | WA | - |
testcase_11 | WA | - |
testcase_12 | WA | - |
testcase_13 | WA | - |
testcase_14 | WA | - |
testcase_15 | WA | - |
testcase_16 | WA | - |
testcase_17 | WA | - |
testcase_18 | WA | - |
testcase_19 | AC | 21 ms
36,732 KB |
testcase_20 | WA | - |
コンパイルメッセージ
In constructor 'trie::node::node()', inlined from 'void __static_initialization_and_destruction_0(int, int)' at main.cpp:92:14, inlined from '(static initializers for main.cpp)' at main.cpp:142:1: main.cpp:90:28: warning: 'void* __builtin_memset(void*, int, long unsigned int)' writing 33733260 bytes into a region of size 33733256 overflows the destination [-Wstringop-overflow=] 90 | REP(i,27)nxt[i]=NONE; | ~~~~~~^~~~~ main.cpp: In function '(static initializers for main.cpp)': main.cpp:92:6: note: at offset 4 into destination object 'trie::g' of size 33733260 92 | }g[312345]; | ^
ソースコード
#include<bits/stdc++.h> using namespace std; typedef long long LL; #define CIN_ONLY if(1) struct cww{cww(){ CIN_ONLY{ ios::sync_with_stdio(false);cin.tie(0); } }}star; #ifdef BTK #define DEBUG if(1) #else #define DEBUG if(0) #endif #define fin "\n" #define FOR(i,bg,ed) for(int i=(bg);i<(ed);i++) #define REP(i,n) FOR(i,0,n) #define ALL(v) (v).begin(),(v).end() #define fi first #define se second #define pb push_back #define REC(ret, ...) std::function<ret (__VA_ARGS__)> template <typename T>inline bool chmin(T &l,T r) {bool a=l>r;if(a)l=r;return a;} template <typename T>inline bool chmax(T &l,T r) {bool a=l<r;if(a)l=r;return a;} template <typename T> istream& operator>>(istream &is,vector<T> &v){ for(auto &it:v)is>>it; return is; } const int mod=1e9+7; // a x + b y = gcd(a, b) // O(log (a+b) ) LL extgcd(LL a, LL b, LL &x, LL &y) { LL g = a; x = 1; y = 0; if (b != 0) g = extgcd(b, a % b, y, x), y -= (a / b) * x; return g; } // mを法とするaの逆元 // O(log a) LL invMod(LL a) { LL x, y; if (extgcd(a, mod, x, y) == 1)return (x + mod) % mod; else return 0; // unsolvable } // 階乗 // O(n) constexpr int SZ=11234; LL fact[SZ]; LL rfact[SZ]; struct fact_{ fact_(){ fact[0]=1; for(int i=1;i<SZ;i++) fact[i]=fact[i-1]*i%mod; rfact[SZ-1]=invMod(fact[SZ-1]); for(int i=SZ-1;i>0;i--){ rfact[i-1]=rfact[i]*i%mod; } } }fact_init; // 組み合わせnCk (mod mod) // O(1) inline LL Comb(LL n,LL k){ LL u=fact[n]; LL d=(rfact[k]*rfact[n-k])%mod; return u*d%mod; } typedef vector<LL> V; namespace trie{ constexpr int NONE=-1; constexpr int root=0; int size=1; struct node{ int count; int nxt[26]; node(){ count=0; REP(i,27)nxt[i]=NONE; } }g[312345]; void push(string s){ int v=root; for(auto& c:s){ c-='a'; if(g[v].nxt[c]==NONE){ g[v].nxt[c]=size++; } v=g[v].nxt[c]; g[v].count++; } } V get_table(int n){ V ret(n+1,0); REP(i,size)ret[g[i].count]++; return ret; } } int main(){ int n; cin>>n; REP(i,n){ string s; cin>>s; trie::push(s); } auto t=trie::get_table(n); V res(n+1,0); FOR(m,1,n+1){ FOR(k,1,n+1){ if(t[k]==0)continue; REP(l,min(m+1,k+1)){ LL o_all =n-k; LL o_need=m-l; if(o_all<o_need)continue; LL other_choose=Comb(o_all,o_need); LL my_choose =Comb(k,l); LL choose=other_choose*my_choose%mod; LL cost=min(l,k-1); res[m]+=choose*t[k]*cost%mod; res[m]%=mod; } } res[m]+=m*Comb(n,m)%mod; res[m]%=mod; res[m]=res[m]*fact[m]%mod; } REP(i,n)cout<<res[i+1]<<fin; return 0; }