203892026-01-06 17:29:53BaKamillaHáromszögekcpp17Wrong answer 11/40201ms1204 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 (auto i : v) std::cout << i << " ";
    std::cout << std::endl << "Mit keresel?\n";
    int m;
    std::cin >> m;
    std::cout << keres_nagy(0, v.size()-1,m);*/
   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 << std::endl;
            std::cout << k - p + 1 << std::endl;
        }
    }
}



SubtaskSumTestVerdictTimeMemory
base11/40
1Accepted0/01ms316 KiB
2Accepted0/01ms316 KiB
3Wrong answer0/017ms316 KiB
4Wrong answer0/44ms316 KiB
5Wrong answer0/24ms508 KiB
6Wrong answer0/1192ms1156 KiB
7Accepted1/1180ms1164 KiB
8Accepted2/2177ms1200 KiB
9Accepted2/2181ms1180 KiB
10Accepted1/1167ms1196 KiB
11Accepted1/1165ms1204 KiB
12Accepted2/2172ms1184 KiB
13Accepted2/2172ms996 KiB
14Wrong answer0/1194ms1196 KiB
15Wrong answer0/1184ms948 KiB
16Wrong answer0/1188ms964 KiB
17Wrong answer0/1188ms1040 KiB
18Wrong answer0/1172ms940 KiB
19Wrong answer0/2172ms944 KiB
20Wrong answer0/2179ms1044 KiB
21Wrong answer0/3182ms980 KiB
22Wrong answer0/5194ms1196 KiB
23Wrong answer0/5201ms1184 KiB