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

Szacowanie czasu sortowania dla n elementów.

Object Storage Arubacloud
0 głosów
137 wizyt
pytanie zadane 28 listopada 2015 w C i C++ przez natrov Gaduła (3,970 p.)
Witam,

Zrobiłem program sortujący n elementową tablicę, ale dla n > 50000 chciałbym wyświetlić szacowany czas wykonania operacji. Ma ktoś jakiś pomysł ? :)

Dzięki :P

1 odpowiedź

0 głosów
odpowiedź 28 listopada 2015 przez notabigthreat Mądrala (7,060 p.)
  1. Pokaż kod
  2. Podaj czasy dla n = 1000,2000,3000,10000,20000,30000
komentarz 28 listopada 2015 przez natrov Gaduła (3,970 p.)
Zroibłem funkcję, która przyjmuje liczbę n a następnie wypisuje szacowany czas.

Nie chciałbym rozpatrywać przedziałami if(n > 10000 && n < 40000) czas = 20;
komentarz 29 listopada 2015 przez notabigthreat Mądrala (7,060 p.)
Powiedzmy, że czas wykonania programu to około (n*n*p + c), gdzie p oraz c są zależne od sprzętu. Dla różnych algorytmów to wyrażenie wygląda różnie, ale to powinno jakoś się zgadzać przy bubblesort.
Przykładowo (dane wymyślone, samo wyrażenie na czas też musisz dostosować):
Dla n=10000 czas wykonania = 20s
Dla n=20000 czas wykonania = 78s
10000*10000*p + c = 20s
20000*20000*p + c = 78s
p*(400000000-100000000) = 78s-20s = 58s
300000000*p = 58s
p = 19.3s / 10^8
c = 0.7s
Wszystko "dowiedziane", mamy wzór:
t = n*n*19.3s/10^8 + 0.7s
Powinieneś mierzyć czas w warunkach podobnych do tych, w których później program będzie uruchamiany.
komentarz 29 listopada 2015 przez natrov Gaduła (3,970 p.)
Serdeczne dzięki kolego  :)

Podobne pytania

0 głosów
0 odpowiedzi 161 wizyt
0 głosów
1 odpowiedź 87 wizyt
pytanie zadane 11 grudnia 2018 w C i C++ przez Programmingc100 Bywalec (2,620 p.)
0 głosów
1 odpowiedź 270 wizyt

92,583 zapytań

141,434 odpowiedzi

319,669 komentarzy

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

...