Submission #4329315
Source Code Expand
#include <bits/stdc++.h>
#define int long long int
#define MOD(x) ((x % MOD_N) + MOD_N) % MOD_N
#define FOR(i,a,b) for(int i=(a);i<(b);++i)
#define FORE(i,a,b) for(int i=(a);i<=(b);++i)
#define RFOR(i,a,b) for(int i=(b)-1;i>=(a);--i)
#define RFORE(i,a,b) for(int i=(b);i>=(a);--i)
#define REP(i,n) FOR(i,0,n)
#define RREP(i,n) RFOR(i,0,n)
#define ALL(c) (c).begin(),(c).end()
#define RALL(c) (c).rbegin(),(c).rend()
#define SORT(c) sort(ALL(c))
#define RSORT(c) sort(RALL(c))
#define SZ(c) (int)((c).size())
#define AUTO(e,v) for(auto e:v)
#define EACH(i,v) for(auto i=v.begin();i!=v.end();++i)
#define REACH(i,v) for(auto i=v.rbegin();i!=v.rend();++i)
#define LB(c,x) distance((c).begin(),lower_bound(ALL(c),x))
#define UB(c,x) distance((c).begin(),upper_bound(ALL(c),x))
#define COUNT(c,x) (lower_bound(ALL(c),x)-upper_bound(ALL(c),x))
#define UNIQUE(c) SORT(c); (c).erase(unique(ALL(c)),(c).end());
#define COPY(c1,c2) copy(ALL(c1),(c2).begin())
#define EXIST(s,e) (bool)((s).find(e)!=(s).end())
#define PB push_back
#define MP make_pair
#define DEL(v) decltype(v)().swap(v)
#define DUMP(x) cerr<<#x<<" = "<<(x)<<endl;
#define NL cerr<<endl;
using namespace std;
template<typename T,typename U> using P=pair<T,U>;
template<typename T> using V=vector<T>;
template<typename T>bool chmax(T&a,T b){if(a<b){a=b;return true;}return false;}
template<typename T>bool chmin(T&a,T b){if(a>b){a=b;return true;}return false;}
template<typename T>T sum(vector<T>&v){return accumulate(ALL(v),T());}
template<typename T>T sum(vector<T>&v,int a,int b){return accumulate(v.begin()+a,v.begin()+b,T());}
template<typename T>T max(vector<T>&v){return *max_element(ALL(v));}
template<typename T>T min(vector<T>&v){return *max_element(ALL(v));}
template<typename T>T max_index(vector<T>&v){return distance((v).begin(),max_element(ALL(v)));}
template<typename T>T min_index(vector<T>&v){return distance((v).begin(),min_element(ALL(v)));}
struct edge { int to, cost; };
template<typename T>auto&operator<<(ostream&s,const vector<T>&v){s<<"[";bool a=1;for(auto e:v){s<<(a?"":" ")<<e;a=0;}s<<"]";return s;}
template<typename T,typename U>auto&operator<<(ostream&s,const pair<T,U>&p){s<<"("<<p.first<<","<<p.second<<")";return s;}
template<typename T>auto&operator<<(ostream&s,const set<T>&st){s<<"{";bool a=1;for(auto e:st){s<<(a?"":" ")<<e;a=0;}s<<"}";return s;}
template<typename T,typename U>auto&operator<<(ostream&s,const map<T,U>&m){s<<"{";bool a=1;for(auto e:m){s<<(a?"":" ")<<e.first<<":"<<e.second;a=0;}s<<"}";return s;}
const int INF = 1e18;
const int MOD_N = 1e9+7;
int LIS(const vector<int>& a) {
int n = a.size();
vector<int> dp(n, INF);
for(int i = 0; i < n; i++) {
*lower_bound(ALL(dp), a[i]) = a[i];
}
return distance(dp.begin(), lower_bound(ALL(dp), INF));
}
signed main()
{
int N; cin >> N;
V<P<int,int>> X(N);
REP(i, N) {
int x, r; cin >> x >> r;
X[i] = MP(x + r, x - r);
}
RSORT(X);
V<int> a(N);
REP(i, N) {
a[i] = X[i].second;
}
int ans = LIS(a);
cout << ans << endl;
return 0;
}
Submission Info
Submission Time |
|
Task |
K - ターゲット |
User |
habara_k |
Language |
C++14 (GCC 5.4.1) |
Score |
5 |
Code Size |
3138 Byte |
Status |
AC |
Exec Time |
88 ms |
Memory |
3328 KB |
Judge Result
Set Name |
All |
Score / Max Score |
5 / 5 |
Status |
|
Set Name |
Test Cases |
All |
00, 01, 02, 03, 04, 05, 06, 07, 90, 91 |
Case Name |
Status |
Exec Time |
Memory |
00 |
AC |
88 ms |
3328 KB |
01 |
AC |
87 ms |
3328 KB |
02 |
AC |
87 ms |
3328 KB |
03 |
AC |
70 ms |
3328 KB |
04 |
AC |
70 ms |
3328 KB |
05 |
AC |
70 ms |
3328 KB |
06 |
AC |
53 ms |
3328 KB |
07 |
AC |
52 ms |
3328 KB |
90 |
AC |
1 ms |
256 KB |
91 |
AC |
1 ms |
256 KB |