結果
問題 | No.1546 [Cherry 2nd Tune D] 思ったよりも易しくない |
ユーザー |
👑 ![]() |
提出日時 | 2021-03-20 03:31:37 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,090 bytes |
コンパイル時間 | 643 ms |
コンパイル使用メモリ | 70,400 KB |
実行使用メモリ | 10,368 KB |
最終ジャッジ日時 | 2024-12-14 19:25:21 |
合計ジャッジ時間 | 16,926 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 5 WA * 48 |
ソースコード
#include<iostream> #include<vector> using namespace std; using ll=long long; ll modulo(ll a, ll mod){ ll b=a%mod; if (b>=0) return b; else return b+mod; } ll sum_mod(vector<ll> a,ll mod){ ll x=0; for (auto p:a) x=modulo(x+p,mod); return x; } ll pow_mod(ll a, ll k, ll mod){ ll x=1; while (k){ if (k&1){ x=modulo(x*a,mod); } a=modulo(a*a,mod); k>>=1; } return x; } ll S(ll b,ll M,ll Mod){ ll x=modulo(b,Mod); x*=b+1; x=modulo(x,Mod); x*=b+2; x=modulo(x,Mod); x*=modulo(4*M+3-3*b,Mod); x=modulo(x,Mod); return x; } int main(){ ll t,v; ll x=0; ll Mod=998244353; int N; cin >> N; vector<ll> T(N,0),V(N,0); for (int i=0;i<N;i++){ cin >> T[i] >> V[i]; } ll T_sum=sum_mod(T,Mod); ll X=0; ll p=1; for (int i=0;i<N;i++){ X=modulo(X+V[i]*(S(p+T[i]-1,T_sum,Mod)-S(p-1,T_sum,Mod)),Mod); p+=T[i]; } ll twenty_four_inv=pow_mod(24,Mod-2,Mod); cout << modulo(X*twenty_four_inv,Mod) << endl; }