Description
data:image/s3,"s3://crabby-images/71cbe/71cbe8931c27e2df59960d57f964700693d40215" alt=""
Submission
class Solution { public: int maxEnvelopes(vector<vector<int>>& envelopes) { sort(envelopes.begin(), envelopes.end(), [](vector<int>& v1, vector<int>& v2) { if(v1[0] == v2[0]) return v1[1] > v2[1]; return v1[0] < v2[0]; } ); vector<int> stk; for(auto& envelope: envelopes) { int x = envelope[1]; if(stk.empty() || stk.back() < x) { stk.push_back(x); } else { auto it = lower_bound(stk.begin(), stk.end(), x); *it = x; } } return stk.size(); } };
data:image/s3,"s3://crabby-images/ebb4a/ebb4abe581c5b7c8408bcec33a2f17e68bc159fe" alt=""