Pereiti prie turinio

Rekomenduojami pranešimai

Gal padekit, kad noriu buti atskirai kiekviena skaiciuoja rezultatus(kintamasiai). Kiek laiko skaiciuoti(time). Kaip padaryti atskirai? Ne isviso, o kiekvieno... HELP

 

 

#include <cstdlib>
#include <ctime>
#include <iostream>
#include <time.h>

void print_array(const int array[], int size);
void sort_array(int array[], int size);

int main()
{
time_t start, end;
double tc;
const int size = 20; 
const int max_v = 100;

int array[size] {}; 
std::srand(std::time(nullptr));
for (int& v : array) v = std::rand() % max_v + 1;
start = clock();
std::cout << "unsorted array:\n\t";
print_array(array, size);

sort_array(array, size);
std::cout << "sorted array:\n\t";
print_array(array, size);

end = clock();
tc = (difftime(end, start) / CLOCKS_PER_SEC);
std::printf("\ttime efficiency is %lf", tc);

}

void print_array(const int array[], int size)
{
if (array == nullptr) return;

for (int i = 0; i < size; ++i) std::cout << array[i] << ' ';
std::cout << '\n';
}

void swap_items(int array[], int a, int b) 
{
const auto temp = array[a];
array[a] = array[b];
array[b] = temp;
}


bool bubble_up(int array[], int size) 
{
bool swapped = false;

for (int i = 0; i < (size - 1); ++i)
{
	if (array[i] > array[i + 1])
	{
		swap_items(array, i, i + 1);
		swapped = true;
	}
}

return swapped;
}

void sort_array(int array[], int size)
{

if (array == nullptr || size < 2) return;


while (bubble_up(array, size));
}

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Antra eilute tai jau pasidare rezultata. Bet noriu buti su kiekvienais kartu kiek skaiciuoja laiko funkcija(kuri paskutine eilute programavau).

 

 

Jeigu teisingai suprantu, nori suzinoti kiek uztruks kiekvienos funkcijos kvietimas.

Jeigu taip, tai tau reik paprasciausiai nuresetint start ir end kintamuju reiksmes. Pavyzdziui:

//Pirmos funkcijos trukmes skaiciavimas
start = clock();
funkcija1();
end = clock();
tc = (difftime(end, start) / CLOCKS_PER_SEC);
std::printf("\ttime efficiency is %lf", tc);

//Antros funkcijos trukmes skaiciavimas
start = clock();
funkcija2();
end = clock();
tc = (difftime(end, start) / CLOCKS_PER_SEC);
std::printf("\ttime efficiency is %lf", tc);

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...