203192026-01-06 13:45:37BaKamillaHáromszögekcpp17Hibás válasz 26/40202ms1196 KiB
#include <iostream>
#include <vector>
#include <algorithm>

std::vector<int> v;

int keres(int elso, int utolso, int mit)
{
    if (elso >= utolso) {
        return elso;
    }
    else {
        int k = (elso + utolso) / 2;
        if (v[k] == mit) return k;
        else if (mit < v[k]) return keres(elso, k - 1, mit);
        else return keres(k + 1, utolso, mit);
    }
}
int main()
{
    int N;
    int Q;
    std::cin >> N >> Q;
    for (int i = 1; i <= N; i++) {
        int a;
        std::cin >> a;
        v.push_back(a);
    }
    sort(v.begin(), v.end());
   for (int i = 1; i <= Q; i++) {
        int a, b; 
        std::cin >> a >> b;
        if (a > b) std::swap(a, b);
        int k = keres(0, v.size(), a + b);
        int p = keres(0, v.size(), b - a);
        if (k >= v.size()) k--;
        else
            if( v[k] >= a + b) k--;
        if (p < 0) p++;
        else if(v[p] <= b - a) p++;
        std::cout << k - p + 1 << std::endl;
    }


}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base26/40
1Elfogadva0/01ms316 KiB
2Elfogadva0/01ms508 KiB
3Elfogadva0/017ms508 KiB
4Elfogadva4/44ms316 KiB
5Elfogadva2/24ms316 KiB
6Elfogadva1/1193ms1196 KiB
7Elfogadva1/1180ms1096 KiB
8Elfogadva2/2181ms1180 KiB
9Elfogadva2/2180ms1076 KiB
10Elfogadva1/1167ms1040 KiB
11Elfogadva1/1170ms944 KiB
12Elfogadva2/2167ms1032 KiB
13Elfogadva2/2170ms992 KiB
14Elfogadva1/1194ms1196 KiB
15Elfogadva1/1185ms964 KiB
16Elfogadva1/1188ms1016 KiB
17Hibás válasz0/1187ms944 KiB
18Hibás válasz0/1172ms992 KiB
19Hibás válasz0/2173ms1000 KiB
20Hibás válasz0/2174ms944 KiB
21Hibás válasz0/3180ms976 KiB
22Hibás válasz0/5194ms1188 KiB
23Elfogadva5/5202ms1152 KiB