summaryrefslogtreecommitdiff
path: root/sem_3/algo/tp1-done/PROG_TP1/mainTP1.cpp
blob: 18d30ab4a05320e92f63325d76b4627b194425b3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#include <iostream>
#include <fstream>
#include <string>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include "outilsTab.h"

using namespace std;


int main(int argc, char ** argv)
{
    int* Tab;
    struct triplet res;
    int sm, taille, q;
    clock_t t1, t2;

    srand(time(NULL));
    printf("Numero de la question traitee (1/2/3/4) ? ");
    scanf("%d",&q);
    switch (q){
        case 1 :
            taille=1000;
            Tab=genTab(taille);
            t1=clock(); sm=ssTabSomMax1(Tab,taille); t2=clock();
            cout << "\n Somme Max1 : " << sm << " tps : " <<  (double) (t2-t1)/  (double) CLOCKS_PER_SEC << endl;
            t1=clock(); sm=ssTabSomMax2(Tab,taille); t2=clock();
            cout << "\n Somme Max2 : " << sm << " tps : " <<  (double) (t2-t1)/  (double) CLOCKS_PER_SEC << endl;
            t1=clock(); sm=ssTabSomMax3(Tab,taille); t2=clock();
            cout << "\n Somme Max3 : " << sm << " tps : " <<  (double) (t2-t1)/  (double) CLOCKS_PER_SEC << endl;
            t1=clock(); sm=ssTabSomMax4(Tab,taille); t2=clock();
            cout << "\n Somme Max4 : " << sm << " tps : " <<  (double) (t2-t1)/  (double) CLOCKS_PER_SEC << endl;

        break;
        case 2 :
            fichierTemps("sm1.dat", 1000, 100, ssTabSomMax1);
            fichierTemps("sm2.dat", 1000, 100, ssTabSomMax2);
            fichierTemps("sm3.dat", 1000, 100, ssTabSomMax3);
            fichierTemps("sm4.dat", 1000, 100, ssTabSomMax4);
            system("gnuplot trace1.gnu");
            fichierTemps("sm2.dat", 20000, 1000, ssTabSomMax2);
            fichierTemps("sm3.dat", 20000, 1000, ssTabSomMax3);
            fichierTemps("sm4.dat", 20000, 1000, ssTabSomMax4);
            system("gnuplot trace2.gnu");
            fichierTemps("sm3.dat", 1000000, 100000, ssTabSomMax3);
            fichierTemps("sm4.dat", 10000000, 1000000, ssTabSomMax4);
            system("gnuplot trace3.gnu");
       break;
        case 3 :
            Tab=genTab(20);
            afficheTab(Tab,20);
            res=indSsTabSomMax(Tab,20);
            cout << "\n somme Max : " << res.somMax << "\n debut souTab : " << res.deb << "\n fin SouTab : " << res.fin << endl;
        break;
        case 4 :
            Tab=genTab(20);
            afficheTab(Tab,20);
            rangerElemNeg(Tab,20);
            afficheTab(Tab,20);
        break;
    }
   return 0;
}