203922026-01-06 17:32:47BaKamillaHáromszögekcpp17Wrong answer 39/40194ms1240 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
base39/40
1Accepted0/01ms316 KiB
2Accepted0/01ms316 KiB
3Accepted0/016ms316 KiB
4Accepted4/44ms500 KiB
5Accepted2/24ms508 KiB
6Wrong answer0/1187ms1136 KiB
7Accepted1/1175ms1160 KiB
8Accepted2/2179ms1072 KiB
9Accepted2/2175ms1240 KiB
10Accepted1/1165ms1200 KiB
11Accepted1/1166ms944 KiB
12Accepted2/2165ms1196 KiB
13Accepted2/2166ms1036 KiB
14Accepted1/1194ms1200 KiB
15Accepted1/1180ms1040 KiB
16Accepted1/1182ms1184 KiB
17Accepted1/1179ms1008 KiB
18Accepted1/1167ms940 KiB
19Accepted2/2172ms944 KiB
20Accepted2/2171ms944 KiB
21Accepted3/3178ms1060 KiB
22Accepted5/5194ms1196 KiB
23Accepted5/5193ms972 KiB