結果
問題 | No.325 マンハッタン距離2 |
ユーザー |
|
提出日時 | 2021-09-18 17:47:51 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
RE
|
実行時間 | - |
コード長 | 2,009 bytes |
コンパイル時間 | 2,589 ms |
コンパイル使用メモリ | 202,332 KB |
最終ジャッジ日時 | 2025-01-24 15:47:18 |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 22 RE * 2 |
ソースコード
#include<bits/stdc++.h>using namespace std;#define rep(i,n) for(ll i=0;i<n;i++)#define repl(i,l,r) for(ll i=(l);i<(r);i++)#define per(i,n) for(ll i=(n)-1;i>=0;i--)#define perl(i,r,l) for(ll i=r-1;i>=l;i--)#define fi first#define se second#define pb push_back#define ins insert#define pqueue(x) priority_queue<x,vector<x>,greater<x>>#define all(x) (x).begin(),(x).end()#define CST(x) cout<<fixed<<setprecision(x)#define vtpl(x,y,z) vector<tuple<x,y,z>>#define rev(x) reverse(x);using ll=long long;using vl=vector<ll>;using vvl=vector<vector<ll>>;using pl=pair<ll,ll>;using vpl=vector<pl>;using vvpl=vector<vpl>;const ll MOD=1000000007;const ll MOD9=998244353;const int inf=1e9+10;const ll INF=4e18;//const ll dy[9]={0,1,-1,0,1,1,-1,-1,0};//const ll dx[9]={1,0,0,-1,1,-1,1,-1,0};template<class T> inline bool chmin(T& a, T b) {if (a > b) {a = b;return true;}return false;}template<class T> inline bool chmax(T& a, T b) {if (a < b) {a = b;return true;}return false;}int main(){vl x(2),y(2);cin >> x[0] >> y[0] >> x[1] >> y[1];ll d;cin >> d;vl pls={y[0],y[1],d,-d,0,y[0]+1,y[1]-1,d-1,-d+1};//交点や変化点のy座標を入れるrep(i,2){pls.push_back(d-abs(x[i]));pls.push_back(-d+abs(x[i]));pls.push_back(d-abs(x[i])-1);pls.push_back(-d+abs(x[i])-1);pls.push_back(d-abs(x[i])+1);pls.push_back(-d+abs(x[i])+1);}sort(all(pls));pls.erase(unique(all(pls)),pls.end());vl np;for(auto ys:pls){if(ys<y[0]||ys>y[1]||ys<-d||ys>d)continue;np.push_back(ys);}vl vals;for(auto ys:np){ll lx=-d+abs(ys),rx=d-abs(ys);chmax(lx,x[0]);chmin(rx,x[1]);ll r=max(rx-lx+1,0LL);vals.push_back(r);}ll ans=0;rep(i,np.size()-1){ans+=(vals[i]+vals[i+1])*(np[i+1]-np[i]+1)/2;ans-=vals[i+1];}cout << ans+vals.back() << endl;}