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

Testowania czasu sortowania

Object Storage Arubacloud
0 głosów
86 wizyt
pytanie zadane 11 grudnia 2018 w C i C++ przez Programmingc100 Bywalec (2,620 p.)
void sortowanie_wybor(long int* tab,long int a,long int n)
{

    int w;
    int minn;
    for(int i=0; i<n; i++)
    {
         minn=tab[i];
        for(int j=i; j<n; j++)
        {
            if(minn>tab[j])
            {
               w=j;
               minn=tab[j];

            }

        }

       int temp;
       temp=tab[w];
       tab[w]=tab[i];
       tab[i]=temp;

    }
}
void sortowanie_bubble(long int* tab,long int a,long int n)
{
    for(int i=0; i<n; i++)
    {
        for(int j=0; j<n; j++)
        {
          if(tab[i]<tab[j])
          {
              int temp;
             temp=tab[i];
             tab[i]=tab[j];
             tab[j]=temp;
          }

        }
    }
}

void test(long int size)
{
   long int T[99999];
    for(int i=0; i<99999; i++)
    {
        T[i]=i;
    }

	double insertion_sort_time = 0;
	double insertion_sort_time1 = 0;
	double test1 = 0;
	clock_t start, end;

	long int *a = generate_random_array(size);
	long int *b = copy_array(a,size);
	start = clock();
	sortowanie_wybor(b,0,size-1);  //wywolanie algorytmu sorotowania
	end = clock();
	insertion_sort_time += ((double) (end - start)) / CLOCKS_PER_SEC;
	free(b);
    long int *c = copy_array(a,size);
    start = clock();
    sortowanie_bubble(c,0,size-1);
    end = clock();
    insertion_sort_time1 += ((double) (end - start)) / CLOCKS_PER_SEC;
    free(c);
    start =clock();
    sortowanie_wybor(c,0,size-1);

    end = clock();
    test1 += ((double) (end - start)) / CLOCKS_PER_SEC;
    std::cout << " Czas sortowania(wybor) " << insertion_sort_time << endl;
    std::cout << "Czas sortowania(bubble) " << insertion_sort_time1 << endl;
    std::cout << "Czas sortowania(max) "   << test1 <<endl;

Mam program sprawdzający czas sortowania ale działa on tak jak trzeba a sam nie mogę znaleźć błędu. Nie rozumie  dlaczego liczy czas jeśli jeden sortuje malejąca a drugi rosnąco ale już nie liczy poprawnie jeśli oba sortują malejąco i nie działa jeśli tworzę tablice posortowaną odwrotnie.

1 odpowiedź

+2 głosów
odpowiedź 11 grudnia 2018 przez RafalS VIP (122,820 p.)
wybrane 13 lipca 2020 przez Programmingc100
 
Najlepsza

clock() nie ma gwarancji dokładności. Spróbuj na steady_clock lub high_resolution_clock

    auto t1 = std::chrono::high_resolution_clock::now();
    f();
    auto t2 = std::chrono::high_resolution_clock::now();
    auto int_ms = std::chrono::duration_cast<std::chrono::milliseconds>(t2 - t1);
    std::cout<<"execution of f took "<<int_ms.count()<<"ms"<<endl;

I nie mieszaj języków. Jak widzę free zaraz obok std::cout to mi sie serce kraja :P

Podobne pytania

0 głosów
1 odpowiedź 269 wizyt
0 głosów
1 odpowiedź 137 wizyt
pytanie zadane 28 listopada 2015 w C i C++ przez natrov Gaduła (3,970 p.)
0 głosów
0 odpowiedzi 372 wizyt
pytanie zadane 13 sierpnia 2021 w PHP przez CSSoup Mądrala (6,460 p.)

92,536 zapytań

141,377 odpowiedzi

319,454 komentarzy

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

...