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

Zadanie SPOJ-Srednia arytmetyczna problem

VPS Starter Arubacloud
0 głosów
186 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 241 wizyt
pytanie zadane 10 kwietnia 2017 w C i C++ przez ChiriChiri Obywatel (1,260 p.)
0 głosów
2 odpowiedzi 331 wizyt
0 głosów
1 odpowiedź 517 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!

...