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

Zadanie Vasya and sets Eolymp, problem z bitsetem / maskami bitowymi

Object Storage Arubacloud
0 głosów
133 wizyt
pytanie zadane 4 kwietnia 2023 w Algorytmy przez pasjonat_algorytmiki Pasjonat (19,540 p.)

Mam problem z takim zadaniem: https://www.eolymp.com/en/contests/14738/problems/149026

Zapewne jest ono jakies proste, napisałem kod na 80pkt(przekroczono limit czasu) przy pomocy bitseta. Zastanawiam się dlaczego nie wchodzi na 100pkt, pewnie coś źle napisałem w bitsecie, czy te and-owanie / or-owanie / count nie powinny działać w O(SIZE / 64)? Jest to moje pierwsze zadanie, w którym skorzystałem z bitseta, więc z góry ostrzegam może być tragicznie....

Kod:

#include <iostream>
#include <vector>
#include <bitset>

using namespace std;

int n = 0, m = 0, z = 0, wczytana_liczba = 0, a = 0, b = 0, wyn = 0;
const unsigned long long SIZE = 1e6+1;
string decyzja;
vector<bitset<SIZE>> czy_mamy;

int main()
{
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);

    cin >> n;
    czy_mamy.assign(n,{});

    for (int i = 0; i < n; ++i)
    {
        cin >> z;
        while(z--)
        {
            cin >> wczytana_liczba;
            czy_mamy[i].set(wczytana_liczba);
        }
    }

    cin >> m;
    for (int i = 0; i < m; ++i)
    {
        cin >> decyzja >> a >> b;
        a--, b--;
        if (decyzja == "INTERSECTION")
            cout << (czy_mamy[a] & czy_mamy[b]).count() << '\n';
        else
            cout << (czy_mamy[a] | czy_mamy[b]).count() << '\n';
    }

    return 0;
}

Z góry dziękuję za pomoc i poświęcony czas!

1 odpowiedź

0 głosów
odpowiedź 4 kwietnia 2023 przez Whistleroosh Maniak (56,980 p.)
wybrane 7 kwietnia 2023 przez pasjonat_algorytmiki
 
Najlepsza
Raczej jest dobrze. Limity czasowe są pewnie kiepsko ustawione. Samo wczytanie 20 * 1e6 liczb z wejścia jest całkiem czasochłonne, więc trzeba bawić się w jakieś mikrooptymalizacje.

Spróbuj zamienić cin na getline i potem sparsuj stringa. Wywołanie getline 20 razy powinno być trochę szybsze niż wywołanie cin 20*1e6 razy.
komentarz 4 kwietnia 2023 przez Whistleroosh Maniak (56,980 p.)
Sprawdziłem na swoim sprzęcie i przy optymalizacji O2, na których chyba przeważnie działają sprawdzarki, getline działa jakieś 9 razy szybciej. Bez O2 działają podobnie, choć getline wciąż minimalnie szybciej
komentarz 7 kwietnia 2023 przez pasjonat_algorytmiki Pasjonat (19,540 p.)

@Whistleroosh, 

chyba limity są źle ustawione. Średnio popisała się ta platforma.

Ale i tak dzięki, napewno to przyśpieszyło,

Podobne pytania

0 głosów
1 odpowiedź 145 wizyt
pytanie zadane 4 lutego 2018 w C i C++ przez Niebieski_Zerg Użytkownik (610 p.)
0 głosów
1 odpowiedź 167 wizyt
pytanie zadane 30 września 2015 w C i C++ przez broda Początkujący (380 p.)
0 głosów
1 odpowiedź 177 wizyt

92,565 zapytań

141,418 odpowiedzi

319,604 komentarzy

61,952 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!

...