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

SPOJ Sort1 - sędzia zwraca błędną odpowiedź

Object Storage Arubacloud
0 głosów
106 wizyt
pytanie zadane 1 czerwca 2022 w C i C++ przez Chrost Nowicjusz (150 p.)

Mój program zwraca dokładnie takie same wyniki jak wyjście w przykładach na SPOJu, jednak sędzia zwraca mi błędną odpowiedź. Proszę o wskazanie miejsca, gdzie szukać przyczyny. 

#include <iostream>
#include <cmath>
using namespace std;

int main()
{
    int ile;
    cin>> ile;

    for (int i=0; i<ile; i++)
    {
        int n, p1,p2, tmp;
        string tmp_name;
        cin >> n;
        int * x = new int [n];
        int * y = new int [n];
        string * nazwa = new string [n];

        for (int j=0;j<n;j++)
        {
            cin >> nazwa[j]>> x[j]>>y[j];
        }

         for (int j=0;j<n;j++)
        {
            for (int k=0; k <n-1; k++)
            {
                p1= sqrt(pow(x[k],2)+pow(y[k],2));
                p2=sqrt(pow(x[k+1],2)+pow(y[k+1],2));
                if (p1>p2)
                {
                    tmp =x[k];
                    x[k]=x[k+1];
                    x[k+1] = tmp;

                    tmp = y[k];
                    y[k]= y[k+1];
                    y[k+1]= tmp;

                    tmp_name = nazwa[k];
                    nazwa[k] = nazwa[k+1];
                    nazwa[k+1] = tmp_name;
                }
            }
        }
        for (int j=0; j<n; j++)
        {
            cout<<nazwa[j]<<" "<<x[j]<<" "<<y[j]<<endl;
        }

        delete [] x;
        delete [] y;
        delete [] nazwa;
    }
    return 0;
}

Każda uwaga będzie dla mnie cenna.

1 odpowiedź

+1 głos
odpowiedź 1 czerwca 2022 przez Great Stary wyjadacz (12,360 p.)

Pomiędzy wypisywanymi zestawami powinna się znaleźć dodatkowa jedna linia odstępu. Wynik pierwiastka nie musi być liczbą całkowitą. Pierwiastkowanie nie jest potrzebne do porównania odległości punktów: 

for (int k = 0; k < n - j - 1; k++)
{
    int p1 = pow(x[k], 2) + pow(y[k], 2);
    int p2 = pow(x[k + 1], 2) + pow(y[k + 1], 2);
    if (p1 > p2)
    {
        swap(x[k], x[k + 1]);
        swap(y[k], y[k + 1]);
        swap(nazwa[k], nazwa[k + 1]);
    }
}

 

komentarz 1 czerwca 2022 przez Chrost Nowicjusz (150 p.)
Dzięki! Twoje uwagi pomogły :)

Podobne pytania

0 głosów
4 odpowiedzi 486 wizyt
0 głosów
3 odpowiedzi 204 wizyt
0 głosów
0 odpowiedzi 250 wizyt

92,575 zapytań

141,425 odpowiedzi

319,650 komentarzy

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

...