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

SKARBFI - SkarbFinder SPOJ

VPS Starter Arubacloud
0 głosów
343 wizyt
pytanie zadane 29 sierpnia 2018 w SPOJ przez Piotr Błaszczak Bywalec (2,890 p.)

Cześć, mam problem z zadaniem ze SPOJA (https://pl.spoj.com/problems/SKARBFI/). Napisałem program który u mnie działa jak należy, ale SPOJ odrzuca mi go z powodu rzekomej "Błędnej odpowiedzi". Wie ktoś dlaczego? Mój kod:

#include <iostream>

using namespace std;

int main()
{
    int t,n,a,b;
    cin>>t;

    while(t>0)
    {
    t--;
    cin>>n;
    int polnoc=0,poludnie=0,wschod=0,zachod=0;
    for(int i=0; i<n; i++)
    {
        cin>>a>>b;
       switch(a)
       {
       case 0: polnoc+=b; break;
       case 1: poludnie+=b; break;
       case 2: wschod+=b; break;
       case 3: zachod+=b; break;
       }
    }
    if(polnoc>=poludnie){polnoc-=poludnie; poludnie=0;}
    else {poludnie-=polnoc; polnoc=0;}
    if(wschod>=zachod){wschod-=zachod; zachod=0;}
    else {zachod-=wschod; wschod=0;}

    if(polnoc==0&&poludnie==0&&wschod==0&&zachod==0)cout<<"studnia"<<endl;
    if(polnoc != 0)cout<<"0 "<<polnoc<<endl;
    if(poludnie != 0)cout<<"1 "<<polnoc<<endl;
    if(wschod != 0)cout<<"2 "<<polnoc<<endl;
    if(zachod != 0)cout<<"3 "<<polnoc<<endl;
    }
    return 0;
}

 

1 odpowiedź

+1 głos
odpowiedź 29 sierpnia 2018 przez RafalS VIP (122,820 p.)
wybrane 29 sierpnia 2018 przez Piotr Błaszczak
 
Najlepsza

Zacząłbym od tego, że niepotrzebnie przechowujesz wszystkie kierunki. Zachód to na wschód tylko z minusem :P Na koniec proste sprawdzenie czy liczba większa od zera.

Wydaje mi się, że błąd jest tutaj:

    if(polnoc != 0)cout<<"0 "<<polnoc<<endl;
    if(poludnie != 0)cout<<"1 "<<polnoc<<endl;
    if(wschod != 0)cout<<"2 "<<polnoc<<endl;
    if(zachod != 0)cout<<"3 "<<polnoc<<endl;

czemu zawsze wypisujesz polnoc?

PS:

int t,n,a,b;

czemu nie jakieś sensowne nazwy jak liczba_zestawow, liczba_par itd?

Podobne pytania

0 głosów
1 odpowiedź 574 wizyt
pytanie zadane 26 lipca 2016 w C i C++ przez am49 Początkujący (420 p.)
0 głosów
0 odpowiedzi 210 wizyt
pytanie zadane 17 listopada 2019 w Python przez TomJar Nowicjusz (230 p.)
0 głosów
1 odpowiedź 231 wizyt

92,453 zapytań

141,262 odpowiedzi

319,088 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...