結果
問題 | No.817 Coin donation |
ユーザー |
![]() |
提出日時 | 2019-04-20 02:40:39 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,124 bytes |
コンパイル時間 | 1,687 ms |
コンパイル使用メモリ | 172,292 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-09-24 18:03:29 |
合計ジャッジ時間 | 3,975 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 11 WA * 3 |
ソースコード
#include <bits/stdc++.h> using namespace std; using ll = long long; #define FOR(i,a,b) for(ll (i)=a;(i)<(b);++(i)) #define RFOR(i,a,b) for(ll (i)=a;(i)>=(b);--(i)) #define REP(i,n) FOR(i,0,n) #define RREP(i,n) RFOR(i,n,0) #define ALL(v) v.begin(), v.end() #define UNIQ(v) sort(ALL(v)); v.erase(unique(ALL(v)), v.end()) #define BIT(n) (1LL<<(n)) #define DEBUG(a) cout << #a << " = " << a << endl const ll inf = 1e15; const ll mod = 1e9+7; int dy[] = {0, 0, 1, -1}; int dx[] = {1, -1, 0, 0}; int main() { int N, K; vector<int> A, B; cin >> N >> K; REP(i, N) { int a, b; cin >> a >> b; A.push_back(a); B.push_back(b); } sort(A.begin(), A.end()); sort(B.begin(), B.end()); int count = 0; for (ll i = 1; i <= K; i++) { auto iter = upper_bound(ALL(A), i); auto iter2 = lower_bound(ALL(B), i); int inc_num = iter - A.begin(); int dec_num = iter2 - B.begin(); count += inc_num - dec_num; if (count >= K) { cout << i << endl; return 0; } } }