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

Quiz z losowaniem kolejności pytań

Object Storage Arubacloud
+1 głos
160 wizyt
pytanie zadane 3 czerwca 2020 w C i C++ przez sun Nowicjusz (130 p.)

Na początku chcę zaznaczyć, że jestem totalnie początkująca!

Chcę napisać w C++ quiz, tylko zależy mi na tym, żeby za każdym razem, kiedy odpalimy program pytania wyświetlały się w różnej kolejności.

Napisałam już quiz i kod losujący liczby bez powtórzeń, jednak nie wiem jak połączyć te dwa kody, tak aby wylosowane liczby decydowały o kolejności pytań.

#include <iostream>
#include <fstream>
#include <cstdlib>
#include <algorithm>
#include <string>
#include <windows.h>
#include <time.h>
 
using namespace std;
 
string temat, nick;
string tresc[5];
string odpA[5], odpB[5], odpC[5], odpD[5];
string poprawna[5];
string odpowiedz;
int punkty=0;
 
int main()
{
    int nr_linii=1;
    string linia;
    int nr_pytania=0;
 
    fstream plik;
    plik.open("quiz.txt",ios::in);
 
    if (plik.good()==false)
    {
        cout<<"Nie udalo sie otworzyc pliku!";
        exit(0);
    }
 
    while(getline(plik,linia))
    {
        switch(nr_linii)
        {
            case 1: temat=linia;                     break;
            case 2: nick=linia;                      break;
            case 3: tresc[nr_pytania] = linia;       break;
            case 4: odpA[nr_pytania] = linia;        break;
            case 5: odpB[nr_pytania] = linia;        break;
            case 6: odpC[nr_pytania] = linia;        break;
            case 7: odpD[nr_pytania] = linia;        break;
            case 8: poprawna[nr_pytania] = linia;    break;
        }
 
        if (nr_linii==8) {nr_linii=2; nr_pytania++;}
        nr_linii++;
    }
 
    plik.close();
 


srand(time(NULL));

    int ile_pytan = 5; 
    int ile_wylosowac = 5; 
    int ile_juz_wylosowano=0; 
    int *wylosowane = new int[ile_wylosowac+1]; 
    bool losowanie_ok;

    for (int i=1; i<=ile_wylosowac; i++)
    {
		do
		{
            int liczba=rand()%ile_pytan+1; 
            losowanie_ok=true;

			for (int j=1; j<=ile_juz_wylosowano; j++)
			{
				if (liczba==wylosowane[j]) losowanie_ok=false;
			}

			if (losowanie_ok==true)
			{
				ile_juz_wylosowano++;
				wylosowane[ile_juz_wylosowano]=liczba;
			}
		} while(losowanie_ok!=true);
    }


	cout<<"Wylosowane numery: ";
    for (int i=1; i<=ile_wylosowac; i++)
    {
		cout<<wylosowane[i]<<" ";
	}
	
	
	
	for (int i=0; i<=4; i++)
    {
        cout<<endl<<tresc[i]<<endl;
        cout<<"A. "<<odpA[i]<<endl;
        cout<<"B. "<<odpB[i]<<endl;
        cout<<"C. "<<odpC[i]<<endl;
        cout<<"D. "<<odpD[i]<<endl;
 
        cout<<"Twoja odpowiedz: ";
        cin>>odpowiedz;
 
        transform(odpowiedz.begin(), odpowiedz.end(), odpowiedz.begin(), ::tolower);
 
        if (odpowiedz==poprawna[i])
        {
            cout<<"Dobrze! Zdobywasz punkt!"<<endl;
            punkty++;
        }
        else cout<<"Zle! Brak punktu! Poprawna odpowiedz: "<<poprawna[i]<<endl;
 
    }
 
    cout<<"Koniec quizu. Zdobyte punkty: "<<punkty;
 
    return 0;
}

Z góry dziękuje za pomoc i wszelkie podpowiedzi!

1 odpowiedź

+1 głos
odpowiedź 3 czerwca 2020 przez nanautzin Obywatel (1,510 p.)

Ja bym to zrobił tak:
W tej pętli przy wyświetlaniu i warunku zamiast "i" dał bym "wylosowane[i+1] - 1"

    for (int i=0; i<=4; i++)
    {
        cout<<endl<<tresc[i]<<endl;
        cout<<"A. "<<odpA[i]<<endl;
        cout<<"B. "<<odpB[i]<<endl;
        cout<<"C. "<<odpC[i]<<endl;
        cout<<"D. "<<odpD[i]<<endl;
  
        cout<<"Twoja odpowiedz: ";
        cin>>odpowiedz;
  
        transform(odpowiedz.begin(), odpowiedz.end(), odpowiedz.begin(), ::tolower);
  
        if (odpowiedz==poprawna[i])
        {
            cout<<"Dobrze! Zdobywasz punkt!"<<endl;
            punkty++;
        }
        else cout<<"Zle! Brak punktu! Poprawna odpowiedz: "<<poprawna[i]<<endl;
  
    }

Np:

cout<<endl<<tresc[wylosowane[i+1] - 1]<<endl;

 

BTW Zapomniałaś o "delete"

int *wylosowane = new int[ile_wylosowac+1];

 

komentarz 4 czerwca 2020 przez sun Nowicjusz (130 p.)
Dziękuję za pomoc!

Teraz działa!
komentarz 4 czerwca 2020 przez sun Nowicjusz (130 p.)

@nanautzin,

Mam jeszcze jedno pytanie, ponieważ zmieniłam ilość pytań w programie oraz dopisałam pytania w pliku tekstowymi i teraz kiedy próbuje uruchomić program wyskakuje powiadomienie, że program przestał działać. Wiecie może czym jest to spowodowane?

komentarz 4 czerwca 2020 przez nanautzin Obywatel (1,510 p.)
Wrzuć kod to zobaczymy
1
komentarz 4 czerwca 2020 przez sun Nowicjusz (130 p.)
Dzięki za pomoc, ale już sobie poradziłam!

Podobne pytania

0 głosów
1 odpowiedź 527 wizyt
pytanie zadane 9 stycznia 2016 w C i C++ przez thekibi27 Bywalec (2,110 p.)
0 głosów
0 odpowiedzi 665 wizyt
pytanie zadane 27 kwietnia 2019 w PHP przez trixter310 Obywatel (1,440 p.)
0 głosów
1 odpowiedź 278 wizyt
pytanie zadane 18 kwietnia 2019 w PHP przez trixter310 Obywatel (1,440 p.)

92,576 zapytań

141,426 odpowiedzi

319,652 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!

...