• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Wyszukiwanie w tablicy

Object Storage Arubacloud
0 głosów
332 wizyt
pytanie zadane 22 marca 2021 w C i C++ przez CheF123 Początkujący (450 p.)

Witam, mam takie zadanie:

Masz daną posortowaną tablicę liczb nieujemnych nie dłuższą niż milion elementów. Dla każdego zapytania o liczbę x odpowiedz, ile liczb w tej tablicy jest nie mniejszych niż xi.

dla liczb :

liczby w tab-3 4 8 11 23 54 996 8710 911147 10001010
zaputania -1 0 8 64 99 114 334 8484 41 911147 1000000000

ma wypisać:

10 10 8 4 4 4 4 3 5 2 0

Mój program:

#include <iostream>
using namespace std;
int tab[1000002];
int b(int l,int p,int z);
int main()
{
    int n,m,z,p,l;
    scanf("%d",&n);
    for(int i=0;i<n;i++){
        scanf("%d",&tab[i]);
    }
    scanf("%d",&m);
    for(int i=1;i<=m;i++){
        scanf("%d",&z);
        p=b(0,n-1,z);
        l=n-p;
        printf("%d ",l);
    }
    return 0;
}
int b(int l,int p,int z)
{
    int sr;
    while(l<=p){
        sr=(l+p)/2;
        if(tab[sr]>=z){
            p = sr-1;
        }
        else
            l = sr+1;
    }
    return sr;
}

Mi wypisuje 10 10 8 4 4 4 4 4 5 2 1

Sprawdzałem to kilka razy  ,ale nie mogę się doszukać błędu.

Z góry dzięki za podpowiedzi!

1 odpowiedź

0 głosów
odpowiedź 22 marca 2021 przez TOM_CPP Pasjonat (22,640 p.)

Przypatrz się swojemu kodowi

  1. Jest to pomieszanie języka C i C++.
  2. Nazwy funkcji, zmiennych nic nie mówią i wprowadzają niepotrzebny zamęt.
  3. Używasz zmiennych globalnych.

Zobacz jak można to zrobić w C++17

#include <iostream>
#include <algorithm>
#include <vector>

using namespace std;

int calculate( const vector<int>& data , int value )
{
    return size(data) - distance( cbegin(data) , lower_bound( cbegin(data), cend(data), value ) );
}

int main()
{
    const vector<int> data = { 3, 4, 8, 11, 23, 54, 996, 8710, 911147, 10001010 };

    for( auto ask : { 1, 0, 8, 64, 99, 114, 334, 8484, 41, 911147, 1000000000 } )
    {
        cout <<  calculate(data,ask) << ' ';
    }
}

https://godbolt.org/z/GfMPrEo6Y

Podobne pytania

0 głosów
1 odpowiedź 293 wizyt
0 głosów
1 odpowiedź 103 wizyt
pytanie zadane 8 listopada 2015 w C i C++ przez rafalmagician Obywatel (1,320 p.)
0 głosów
2 odpowiedzi 786 wizyt
pytanie zadane 10 sierpnia 2018 w PHP przez niezalogowany

92,632 zapytań

141,502 odpowiedzi

319,880 komentarzy

62,014 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...