Submission #346637

#TimeUsernameProblemLanguageResultExecution timeMemory
346637YJUStrange Device (APIO19_strange_device)C++14
65 / 100
521 ms17760 KiB
#include<bits/stdc++.h> #pragma GCC optimize("unroll-loops,no-stack-protector") using namespace std; typedef long long ll; typedef long double ld; typedef pair<ll,ll> pll; const ll MOD=1e9+7; const ll MOD2=998244353; const ll N=2e5+5; const ld pi=acos(-1); const ll INF=1e18; #define SQ(i) ((i)*(i)) #define REP(i,n) for(ll i=0;i<n;i++) #define REP1(i,n) for(ll i=1;i<=n;i++) #define pb push_back #define mp make_pair #define X first #define Y second #define setp setprecision #define lwb lower_bound #define SZ(_a) (ll)_a.size() ll n,a,b,ans,last,x,y; vector<pll> v; int main(){ ios_base::sync_with_stdio(0);cin.tie(0); cin>>n>>a>>b; ll g=__gcd(a,b+1); if((ld)a/g*b>1e18){ REP(i,n)cin>>x>>y,ans+=y-x+1; cout<<ans<<"\n";return 0; } ll ab=(a/g*b); REP(i,n){ cin>>x>>y; x%=ab;y%=ab; if(x>y){ v.pb(mp(x,ab)); v.pb(mp(0,y+1)); }else{ v.pb(mp(x,y+1)); } } sort(v.begin(),v.end()); for(auto i:v){ ans+=max(0LL,i.Y-max(last,i.X)); last=max(last,i.Y); } cout<<min(ans,ab)<<"\n"; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...