結果
問題 |
No.789 範囲の合計
|
ユーザー |
|
提出日時 | 2024-09-17 00:49:35 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 219 ms / 1,000 ms |
コード長 | 806 bytes |
コンパイル時間 | 2,077 ms |
コンパイル使用メモリ | 205,852 KB |
最終ジャッジ日時 | 2025-02-24 09:04:03 |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 15 |
ソースコード
#include <bits/stdc++.h> using namespace std; #define rep(i,n) for(ll i=0;i<n;i++) using ll = long long; #include<atcoder/segtree> using namespace atcoder; ll op(ll a,ll b){return a+b;}; ll e(){return 0;}; int main() { cin.tie(nullptr); ios::sync_with_stdio(false); ll N; cin>>N; map<ll,ll> M; vector<ll> T(N),X(N),Y(N); for(int i=0;i<N;i++){ cin>>T[i]>>X[i]>>Y[i]; if(T[i]==0)M[X[i]]=1; else M[X[i]]=M[Y[i]]=1; } int cnt=0; for(auto m:M)M[m.first]=cnt,cnt++; segtree<ll,op,e> seg(cnt+10); ll an=0; for(int i=0;i<N;i++){ if(T[i]==0){ ll p=seg.get(M[X[i]]); seg.set(M[X[i]],p+Y[i]); } else{ an+=seg.prod(M[X[i]],M[Y[i]]+1); } } cout<<an<<endl; }