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

Zadanie SPOJ-Srednia arytmetyczna problem

Object Storage Arubacloud
0 głosów
187 wizyt
pytanie zadane 11 maja 2016 w C i C++ przez DualOxygen Użytkownik (810 p.)
edycja 13 maja 2016 przez DualOxygen

Witam byłby ktoś w stanie wytłumaczyć mi co jest nie tak w tym kodzie że nie wyświetla on liczby najbliższej średniej(już kiedyś założyłem podobny temat ale z tego co pamiętam ze problemem nie za bardzo sb poradziłem :P, wtedy używałem fukdji fabs() tutaj na razie nie chcę jej wykorzystywać) 
http://pl.spoj.com/problems/PP0604A/
EDIT:
Nowy kod źródłowy- zrobiłem kilka testów i na moim kompilatorze działa wszystko poprawnie, niestety spoj nie akceptuje zadania prosze o ewentualną podpoiwiedź :P

 

#include<iostream>
using namespace std;
int main()
{
    int najblizszy(0);
    int howMuch_Tests;
    cout<<"Wpisz liczbe testow"<<endl;
    cin>>howMuch_Tests;//wpisuje liczbe testów
    for (int j=1;j<=howMuch_Tests;j++)
    {
    double nearestNumber_copy=0;
    double nearestNumber=0;
    double allNumbers=0;//Przechowuje wszystkie liczby
    int ammount=0;
    double average=0;
    int table[100];
    int howMuch_Numbers;
    cout<<"Ile liczb ma byc w tabeli"<<endl;
    cin>>howMuch_Numbers;
        for (int k=0;k<=howMuch_Numbers;k++)
        {
            cin>>table[k];
            ++allNumbers;
            ammount+=table[k];

        }
         average=ammount/allNumbers;
         cout<<"Srednia !!!!!!!"<<average<<endl;
         //cout<<ammount<<endl;
         //cout<<allNumbers<<endl;
         for(int i=0;i<=howMuch_Numbers;i++)
         {
           if (table[i]<average)
           {
                nearestNumber_copy=average-table[i];
                if (nearestNumber==0 or nearestNumber>nearestNumber_copy)
                {
                    nearestNumber=nearestNumber_copy;
                    if(nearestNumber=nearestNumber_copy)
                   {
                       najblizszy=table[i];
                   }
                }
           }
           else if (table[i]==average)
           {
               najblizszy=table[i];
           }
           else if (table[i]>average)
           {
               nearestNumber_copy=table[i]-average;//3.2-3=0.2
               if (nearestNumber==0 or nearestNumber>nearestNumber_copy)
               {
                   nearestNumber=nearestNumber_copy;
                   if(nearestNumber=nearestNumber_copy)
                   {
                       najblizszy=table[i];
                   }
               }
           }


         }
           cout<<najblizszy<<endl;
    }
    return 0;
}

 

2 odpowiedzi

0 głosów
odpowiedź 13 maja 2016 przez DualOxygen Użytkownik (810 p.)
Podbijam
0 głosów
odpowiedź 13 maja 2016 przez Marcin_N_97 Stary wyjadacz (10,290 p.)
Nie miałem czasu przeanalizować Twojego kodu dokładnie, ale wydaje mi się, że są prostsze sposoby na wykonanie tego zadania. Ja np zrobiłem go takimi:

- odejmujesz od każdej liczby średnią tych liczb (obliczoną w whilu) i potem jeżeli ujemna to mnożysz razy -1 i zapisujesz wskaźnik na nią (jeszcze przed odjęciem). Potem wybierasz najmniejszą z tych wartości i po wskaźniku dochodzisz jaka to byłą liczba

 

- Obliczasz średnią i potem coś a'la metoda sortowania bąbelkowego. Mniejsza po lewo, większa po prawo. I potem z pierwszej liczby po lewej i po prawej dajesz sumę dzieloną przez 2. Jeżeli mniejsza od średniej to liczba po lewej wywołujesz, jak większa to liczba po prawej.

Podobne pytania

0 głosów
2 odpowiedzi 242 wizyt
pytanie zadane 10 kwietnia 2017 w C i C++ przez ChiriChiri Obywatel (1,260 p.)
0 głosów
2 odpowiedzi 334 wizyt
0 głosów
1 odpowiedź 522 wizyt

92,579 zapytań

141,432 odpowiedzi

319,663 komentarzy

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

...