結果
| 問題 |
No.230 Splarraay スプラレェーイ
|
| コンテスト | |
| ユーザー |
沙耶花
|
| 提出日時 | 2021-11-16 23:15:29 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,720 bytes |
| コンパイル時間 | 4,338 ms |
| コンパイル使用メモリ | 251,172 KB |
| 最終ジャッジ日時 | 2025-01-25 18:53:04 |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 5 WA * 10 TLE * 2 |
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:24:22: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
24 | scanf("%d %d %d",&x,&l,&r);
| ~~~~~^~~~~~~~~~~~~~~~~~~~~
ソースコード
#include <stdio.h>
#include <bits/stdc++.h>
#include <atcoder/all>
using namespace atcoder;
using mint = modint1000000007;
using namespace std;
#define rep(i,n) for (int i = 0; i < (n); ++i)
#define Inf 1000000001
#define sz 300
int main(){
int N,Q;
cin>>N>>Q;
vector<int> a(N,0);
int cnt = (N+sz-1)/sz;
vector<int> lazy(cnt,0);
vector<int> Ac(cnt,0),Bc(cnt,0);
long long A=0,B=0;
rep(_,Q){
int x,l,r;
scanf("%d %d %d",&x,&l,&r);
if(x==0){
int AA = 0,BB = 0;
while(l<=r){
if(l%sz==0 || l+sz>r){
int rr;
rr = ((l+sz)/sz)*sz-1;
if(rr>r)rr = r;
for(int i=l;i<=rr;i++){
if(lazy[i/sz]==1||(lazy[i/sz]==0&&a[i]==1))AA++;
if(lazy[i/sz]==2||(lazy[i/sz]==0&&a[i]==2))BB++;
}
l = rr+1;
}
else{
AA += Ac[l/sz];
BB += Bc[l/sz];
l += sz;
}
}
if(AA>BB)A += AA;
if(AA<BB)B += BB;
}
else{
while(l<=r){
if(l%sz!=0 || l+sz>r){
int rr;
rr = ((l+sz)/sz)*sz-1;
if(rr>r)rr = r;
if(lazy[l/sz]!=0){
for(int i=(l/sz)*sz;i<min(N,(l/sz)*sz+sz);i++){
a[i] = lazy[l/sz];
}
lazy[l/sz] = 0;
}
//cout<<l<<','<<rr<<endl;
for(int i=l;i<=rr;i++)a[i] = x;
Ac[l/sz] = 0;
Bc[l/sz] = 0;
for(int i=(l/sz)*sz;i<min(N,(l/sz)*sz+sz);i++){
if(a[i]==1)Ac[l/sz]++;
if(a[i]==2)Bc[l/sz]++;
}
l = rr+1;
}
else{
//cout<<l/sz<<endl;
lazy[l/sz] = x;
Ac[l/sz] = 0;
Bc[l/sz] = 0;
int t = min(N,l+sz) - l;
//cout<<t<<endl;
if(x==1)Ac[l/sz] = t;
else Bc[l/sz] = t;
l += sz;
}
}
}
}
rep(i,cnt){
A += Ac[i];
B += Bc[i];
}
cout<<A<<' '<<B<<endl;
return 0;
}
沙耶花