THMMY.gr

Μαθήματα Βασικού Κύκλου => Δομημένος Προγραμματισμός => Topic started by: Talaipa on November 28, 2016, 18:56:18 pm



Title: [Δομημένος Προγραμματισμός] Άσκηση 3 (Ημ/νία λήξης: 4/12/2016)
Post by: Talaipa on November 28, 2016, 18:56:18 pm


Nα φτιάξετε μια συνάρτηση η οποία να εξομοιώνει ένα ζάρι. Στη συνέχεια να καλέσετε τη συνάρτηση 1.000.000 φορές και να υπολογίσετε τη συχνότητα εμφάνισης του κάθε αριθμού του ζαριού. Στο τέλος του πρόγραμματος θα τυπώνει πόσες φορές εμφανίστικε το κάθε νούμερο.

Για να δημιουργείται κάθε φορά τυχαίους «διαφορετικούς» αριθμούς μπορείτε να χρησιμοποιήσετε τον ακόλουθο κώδικα

time_t t;

srand(time(&t));


Title: Re: [Δομημένος Προγραμματισμός] Άσκηση 3 (Ημ/νία λήξης: 4/12/2016)
Post by: TheoProt on November 29, 2016, 03:37:30 am
Έχει κάνει καθόλου στη θεωρία κεφάλαιο για pointers ;






edit: tag


Title: Re: [Δομημένος Προγραμματισμός] Άσκηση 3 (Ημ/νία λήξης: 4/12/2016)
Post by: Talaipa on November 29, 2016, 10:53:33 am
όχι!


Title: Re: [Δομημένος Προγραμματισμός] Άσκηση 3 (Ημ/νία λήξης: 4/12/2016)
Post by: kostino on November 30, 2016, 05:48:15 am
αν αντι για time_t t; srand(time(&t)); χρησιμοποιησω srand(time(NULL)); αλλαζει τιποτα?


Title: Re: [Δομημένος Προγραμματισμός] Άσκηση 3 (Ημ/νία λήξης: 4/12/2016)
Post by: Oumuamua on December 04, 2016, 13:57:28 pm
Λύση ?


Title: Re: [Δομημένος Προγραμματισμός] Άσκηση 3 (Ημ/νία λήξης: 4/12/2016)
Post by: Apostolof on December 04, 2016, 16:16:30 pm
Λύση ?

Code:
#include <stdlib.h>
#include <stdio.h>

#define N_repeats 1000000

void main(){

int i;
int number1 = 0; //Ενας counter που θα μετρα τις εμφανισεις του 1
int number2 = 0; //Ομοια για το 2 κλπ.
int number3 = 0;
int number4 = 0;
int number5 = 0;
int number6 = 0;

//Οριζουμε μια μεταβλητη τυπου time_t με την οποια seedαρουμε την srand
//ετσι σε καθε εκτελεση του αλγοριθμου θα ξεκιναμε απο διαφορετικο σημειο
//της rand και αρα θα παιρνουμε διαφορετικα νουμερα

    time_t t; //επιστεφει το χρονο σε δευτερολεπτα που περασε απο την 1 Ιαν 1970 (νομιζω)
    srand(time(&t));


    for (i=0; i<N_repeats; i++){
    //Χρησιμοποιουμε μια switch case αλλα γινετε και με 6 if
    //Στην switch case δεν ξεχναμε τα break αλλιως θα "μπει" σε ολα τα cases
    switch(dice_roll()){
    case 1:
    number1++; //Αυξανουμε τον counter των ασσων κατα 1
    break;
    case 2:
    number2++; //Αυξανουμε τον counter των δυαριων κατα 1 κλπ...
    break;
    case 3:
    number3++;
    break;
    case 4:
    number4++;
    break;
    case 5:
    number5++;
    break;
    case 6:
    number6++;
    break;
    }
    }

    //Εμφανιζουμε τις συχνοτητες
    //Για να γινει σωστα η διαιρεση αλλαζουμε τον τυπο των counters μας απο int σε float
    //Χρησιμοποιουμε %f για να εμφανισουμε τον δεκαδικο που παραγεται απο τη διαιρεση
    printf("Freq 1: %f%\n", (float) number1 / N_repeats * 100);
    printf("Freq 2: %f%\n", (float) number2 / N_repeats * 100);
    printf("Freq 3: %f%\n", (float) number3 / N_repeats * 100);
    printf("Freq 4: %f%\n", (float) number4 / N_repeats * 100);
    printf("Freq 5: %f%\n", (float) number5 / N_repeats * 100);
    printf("Freq 6: %f%\n\n", (float) number6 / N_repeats * 100);

    //Και τους αριθμους εμφανισεων
    printf("Num of 1: %d \n", number1);
    printf("Num of 2: %d \n", number2);
    printf("Num of 3: %d \n", number3);
    printf("Num of 4: %d \n", number4);
    printf("Num of 5: %d \n", number5);
    printf("Num of 6: %d", number6);
}

int dice_roll(){
//Η rand() θα επιστρεψει ενα νουμερο στο [0,RAND_MAX] με RAND_MAX > 32767
    //Το rand() % 6 θα δωσει ενα νουμερο στο [0, 5] και με το + 1  στο [1,6]
return rand() % 6 + 1;
}

εδιτ: δε πρόσεξα ότι έλεγε συνάρτηση


Title: Re: [Δομημένος Προγραμματισμός] Άσκηση 3 (Ημ/νία λήξης: 4/12/2016)
Post by: George_RT on December 05, 2016, 14:34:43 pm
Λύση ?
Και μια δικιά μου εκδοχή

Code:
/*------------------------------------Άσκηση 3---------------------------------------------*/
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define REPEATS 1000000

//Δημιουργία τυχαίων αριθμών  [1,6]
int randdice()
{
return (rand() % 6) + 1 ;
}


void calcfr()
{
time_t t;
srand(time(&t));
int frequency[6]={0};
unsigned int i,j;

for(i=0;i<REPEATS;i++)
{
int te=randdice();
frequency[te - 1]++; //Μετρητής , ελέγχει τι έφερε το ζάρι και αυξάνει +1 στον πίνακα τον αντίστοιχο αριθμό
printf("%d ", te);
}
printf("\n");
for(j=0;j<6;j++)
{
printf("Ο αριθμός %d εμφανίστηκε %d φορές με συχνότητα εμφάνισης   %lf  \n",j+1,frequency[j],(float)frequency[j]/REPEATS);
}
}

int main(int argc, char *argv[])
{
system("chcp 1253");
calcfr();
return 0;
}