230252026-01-16 10:50:53Gervid20G (40 pont)cpp17Hibás válasz 0/4017ms1852 KiB
#include <iostream>
#include <vector>
#include <queue>
#include <stack>
#include <set>
#include <map>
#include <limits.h>
#include <algorithm>
#include <math.h>
#include <array>

using namespace std;
using ll = long long;

signed main()
{
	iostream::sync_with_stdio(0);
	cin.tie(0);

	int n, q;
	cin >> n >> q;
	vector<int> houses(n);
	for (int i = 0; i < n; i++) cin >> houses[i];

	vector<array<int, 2>> h; //ascending in heights by leaving out elements {height, origIdx}
	h.reserve(n);
	h.push_back({houses[0], 0});
	for (int i = 1; i < n; i++) {
		if (houses[i] <= h.back()[0]) continue;
		h.push_back({ houses[i], i });
	}

	while (q--) {
		int m;
		cin >> m;
		array<int, 2> v = { m, INT_MAX };
		cout << lower_bound(h.begin(), h.end(), v).operator*()[1] + 1;
	}
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base0/40
1Hibás válasz0/01ms316 KiB
2Hibás válasz0/013ms844 KiB
3Hibás válasz0/21ms316 KiB
4Hibás válasz0/21ms316 KiB
5Hibás válasz0/21ms316 KiB
6Hibás válasz0/21ms500 KiB
7Hibás válasz0/31ms428 KiB
8Hibás válasz0/316ms1600 KiB
9Hibás válasz0/316ms1548 KiB
10Hibás válasz0/316ms1852 KiB
11Hibás válasz0/416ms1588 KiB
12Hibás válasz0/416ms1608 KiB
13Hibás válasz0/417ms1604 KiB
14Hibás válasz0/416ms1588 KiB
15Hibás válasz0/416ms1588 KiB