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

Optymalizacja kodu, Totolotek. Niechlujne porównywanie wartości w dwóch tablicach.

Object Storage Arubacloud
0 głosów
283 wizyt
pytanie zadane 10 sierpnia 2016 w C i C++ przez Zekkeyo Nowicjusz (190 p.)

Napisałem sobie totolotka. Niby okej, ale postanowiłem zapisać liczby użytkownika jak te wylosowane przez komputer do tablic. Problem pojawił się, gdy trzeba było wymyślić pętle do porównanie tych tablic. Łącznie 36 porównań = 6 liczb użytkownika oraz 6 wylosowanych. Wykminiłem, ale mam wrażenie, że to jest mega słabe. Macie jakiś pomysł? Ostatnia pętla.

#include <iostream>
#include <windows.h>
#include <time.h>


using namespace std;

int main()
{
    cout << "Witaj w losowaniu Duzego Lotka! Wybierz swoje 6 liczb z przedzialu 1-49: " << endl << endl;

    srand(time(NULL));
    int tablica_liczb_uzytkownika[6];
    int tablica_liczb_wylosowanych[6];

    for (int i=0; i<= 5; i++)
    {
        tablica_liczb_wylosowanych[i] = rand()%49+1; // losowanie
        cout << "Prosze podac " << i+1 << " liczbe: ";
        cin >> tablica_liczb_uzytkownika[i];

    }

    cout << "\n\nLosowanie nastapi za "; // no dobra, torche oszukane

    for (int i=3; i>=1; i--)
    {
        cout << i;
        Sleep(1000);
        cout << '\b'; // usun znak poprzedzajacy kursor
    }

    cout << "\r                      " << "\rWylosowane liczby to: " << endl; // ustaw kursor na poczatku, wstaw spacje, zastap

    for (int i=0; i<= 5; i++)
    {
        cout << "\nWylosowana liczba" << i+1 <<  ": " << tablica_liczb_wylosowanych[i];
    }

    int trafienia = 0;

    for (int i=0, j=0; i<6;)
    {
        if(tablica_liczb_uzytkownika[i] == tablica_liczb_wylosowanych[j])
        {
           trafienia++;
        }
        j++;

        if(j == 6)
        {
            i++;
            j=0;
        }
    }

    cout << "\n\nIlosc twoich trafien: " << trafienia;

    return 0;
}

Dziękuję za pomoc!

2 odpowiedzi

0 głosów
odpowiedź 10 sierpnia 2016 przez MichuDev Pasjonat (20,300 p.)
  • Podziel program na funkcje.
  • rand() nie jest dobrym pomysłem jeśli chodzi o taką losowość jaka ma być krytyczną w aplikacji. Lepiej użyć silników losowości i rozkładów.
  • Ostatnią pętlę zamieniłbym na taką: 
    for(int i=0;i<6;i++){
      if(tablicz_liczb_uzytkownika[i] == tablica_liczb_wylosowanych[i]) trafienia++;
    }

     

komentarz 10 sierpnia 2016 przez Zekkeyo Nowicjusz (190 p.)
Dzięki za rady. Z funkcjami jak się zaprzyjaźnię to spróbuję. Z silnikami losowości chyba sobie dam siana, chyba przerzucę się na Javę.

Co do pętli - to było pierwsze co przyszło mi na myśl. Ale ta pętla porównuje tylko jeden do jednego, a chyba może być tak, że wylosowano 1 3 5 9 11 13 a ja zaznaczyłem 13 9 11 42 43 44. Wtedy tez mam trójkę, o ile się nie mylę.
komentarz 10 sierpnia 2016 przez adas94 Nałogowiec (29,200 p.)

for(int i=0;i<6;i++){
    for(int j=0;j<6; j++) {
    if(tablicz_liczb_uzytkownika[i] == tablica_liczb_wylosowanych[j])
        trafienia++;
     }
}

Teraz już masz każdego z każdym ;)

0 głosów
odpowiedź 10 sierpnia 2016 przez criss Mędrzec (172,590 p.)
Jest ok, ale niepotrzebnie skomplikowales ta pętle. Wystarczy coś takiego : for (int i = 0; i < 6; i++) for (int i = 0; i < 6; i++) if (chosen[i] == random[j]) trafienia++; Sorry ze bez ramki kodu ale jestem na fonie Masakra co się stało z tym postem. Poprawie na PC

Podobne pytania

0 głosów
4 odpowiedzi 222 wizyt
pytanie zadane 14 lutego 2016 w C i C++ przez salvatoreone Początkujący (270 p.)
0 głosów
1 odpowiedź 265 wizyt
0 głosów
4 odpowiedzi 269 wizyt

92,579 zapytań

141,430 odpowiedzi

319,657 komentarzy

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

...