203762026-01-06 17:15:36BaKamillaHáromszögekcpp17Hibás válasz 39/40194ms1196 KiB
// Haromszogek.cpp : This file contains the 'main' function. Program execution begins and ends there.
//

#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 keres_nagy(int elso, int utolso, int mit) {
    
    if (v[elso] > mit) return elso;
    if (v[utolso] < mit ) return -1;
        int k = (elso + utolso) / 2;
        if (v[k] == mit) return k - 1;
        if (v[k] < mit && mit < v[k + 1]) return k + 1;
        if (mit < v[k]) return keres_nagy(elso, k , mit);
        else return keres_nagy(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);
        if (a + b <= v[0] || a - b >= v[v.size() - 1]) std::cout << 0;
        else {
            int k = keres(0, v.size()-1, a + b);
            int p = keres(0, v.size()-1, 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
base39/40
1Elfogadva0/01ms316 KiB
2Elfogadva0/01ms508 KiB
3Elfogadva0/016ms508 KiB
4Elfogadva4/44ms316 KiB
5Elfogadva2/23ms316 KiB
6Hibás válasz0/1182ms1096 KiB
7Elfogadva1/1173ms1192 KiB
8Elfogadva2/2177ms1168 KiB
9Elfogadva2/2180ms1148 KiB
10Elfogadva1/1165ms1192 KiB
11Elfogadva1/1165ms944 KiB
12Elfogadva2/2165ms988 KiB
13Elfogadva2/2165ms1196 KiB
14Elfogadva1/1193ms1192 KiB
15Elfogadva1/1181ms1052 KiB
16Elfogadva1/1180ms1040 KiB
17Elfogadva1/1181ms1012 KiB
18Elfogadva1/1171ms940 KiB
19Elfogadva2/2171ms1128 KiB
20Elfogadva2/2172ms944 KiB
21Elfogadva3/3174ms1000 KiB
22Elfogadva5/5194ms1096 KiB
23Elfogadva5/5193ms1196 KiB