結果
問題 |
No.1290 Addition and Subtraction Operation
|
ユーザー |
👑 ![]() |
提出日時 | 2020-11-17 23:23:06 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 104 ms / 2,000 ms |
コード長 | 416 bytes |
コンパイル時間 | 1,926 ms |
コンパイル使用メモリ | 195,888 KB |
最終ジャッジ日時 | 2025-01-16 01:28:25 |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 85 |
ソースコード
#include<bits/stdc++.h> using namespace std; using I=long long; #define R(i,n) for(I i=0;i<(n);i++) vector<I>v(2e5),A(2e5),s(2e5); I r(I a){return v[a]-a?v[a]=r(v[a]):a;} int main(){ I n,q,y=1;cin>>n>>q; R(i,n)cin>>A[i]; R(i,n)if(i&1)A[i]*=-1; R(i,n)A[n-i]-=A[n-i-1]; n++;R(i,n)v[i]=i; R(i,q){I a,b;cin>>a>>b;v[r(--a)]=r(b);} R(i,n)s[r(i)]+=A[i]; R(i,n)if(s[i])y=0; cout<<(y?"YES\n":"NO\n"); return 0; }