結果
| 問題 |
No.647 明太子
|
| コンテスト | |
| ユーザー |
merom686
|
| 提出日時 | 2018-02-11 01:35:14 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 7 ms / 4,500 ms |
| コード長 | 2,036 bytes |
| コンパイル時間 | 1,361 ms |
| コンパイル使用メモリ | 97,372 KB |
| 実行使用メモリ | 5,376 KB |
| 最終ジャッジ日時 | 2024-06-27 02:39:53 |
| 合計ジャッジ時間 | 2,127 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 20 |
ソースコード
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <functional>
#include <cstdio>
#include <cstring>
#include <cmath>
using namespace std;
void coco(vector<int>& v) {
size_t n = v.size();
vector<pair<int, int>> t(n);
for (int i = 0; i < n; i++) {
t[i] = { v[i], i };
}
sort(t.begin(), t.end());
int k = 0;
for (int i = 0; i < n; i++) {
if (i > 0 && t[i].first != t[i - 1].first) k++;
v[t[i].second] = k;
}
}
struct BIT {
BIT(int n) : b(n + 1), n(n) {}
void add(int i, int v) {
for (int k = i + 1; k <= n; k += k & -k) b[k] += v;
}
int sum(int k) {
int s = 0;
for (; k > 0; k -= k & -k) s += b[k];
return s;
}
vector<int> b;
int n;
};
int main() {
ios::sync_with_stdio(false);
cin.tie(0);
int n;
cin >> n;
vector<int> a(n), b(n);
for (int i = 0; i < n; i++) {
cin >> a[i] >> b[i];
}
int m;
cin >> m;
a.resize(n + m);
b.resize(n + m);
for (int i = 0; i < m; i++) {
cin >> a[n + i] >> b[n + i];
}
coco(a);
coco(b);
vector<pair<int, int>> p(n);
vector<pair<pair<int, int>, int>> q(m);
for (int i = 0; i < n; i++) {
p[i] = { a[i], b[i] };
}
for (int j = 0; j < m; j++) {
q[j].first = { a[n + j], b[n + j] };
q[j].second = j;
}
sort(p.begin(), p.end(), greater<>());
sort(q.begin(), q.end(), greater<>());
int l = *max_element(b.begin(), b.begin() + n) + 1;
BIT bt(l);
vector<int> c(m);
int i = 0;
for (int j = 0; j < m; j++) {
while (i < n && p[i].first >= q[j].first.first) {
bt.add(p[i++].second, 1);
}
c[q[j].second] = bt.sum(min(l, q[j].first.second + 1));
}
int r = *max_element(c.begin(), c.end());
if (r == 0) {
cout << 0 << endl;
} else {
for (int j = 0; j < m; j++) {
if (c[j] == r) cout << j + 1 << '\n';
}
}
return 0;
}
merom686